Skip to content

Commit

Permalink
Rewrite as ES6 module and update build pipeline
Browse files Browse the repository at this point in the history
  • Loading branch information
zeusdeux committed Mar 12, 2017
1 parent 4f1b6f5 commit d5c0a65
Show file tree
Hide file tree
Showing 36 changed files with 949 additions and 7,013 deletions.
12 changes: 12 additions & 0 deletions .eslintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"root": true,
"extends": "standard",
"env": {
"jquery": true,
"mocha": true
},
"rules": {
"space-before-function-paren": 0,
"no-multiple-empty-lines": [2, {"max": 2}]
}
}
21 changes: 0 additions & 21 deletions .jsbeautifyrc

This file was deleted.

62 changes: 0 additions & 62 deletions .jshintrc

This file was deleted.

7 changes: 2 additions & 5 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
language: node_js
node_js:
- "0.10"
- "0.12"
- "4.1"
- "5.4"
- "node"
script:
npm run-script build
npm run build
62 changes: 0 additions & 62 deletions Gruntfile.js

This file was deleted.

2 changes: 1 addition & 1 deletion examples/advanced-viewport.html
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@
</style>
<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/1.9.0/jquery.min.js">
</script>
<script src="./isInViewport.js">
<script src="../lib/isInViewport.js">
</script>
<script src="./advanced-viewport.js">
</script>
Expand Down
2 changes: 1 addition & 1 deletion examples/advanced.html
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@
</style>
<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/1.7/jquery.min.js">
</script>
<script src="./isInViewport.js">
<script src="../lib/isInViewport.js">
</script>
<script src="./advanced.js">
</script>
Expand Down
2 changes: 1 addition & 1 deletion examples/basic.html
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
</style>
<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/1.7/jquery.min.js">
</script>
<script src="./isInViewport.js">
<script src="../lib/isInViewport.js">
</script>
<script src="./basic.js">
</script>
Expand Down
2 changes: 1 addition & 1 deletion examples/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ <h1>isInViewport.js</h1>
Custom viewport demo
</a>
<a href="./tests/tests.html" class="demos tests">
Tests &amp; code coverage
Tests
</a>
</div>
</body>
Expand Down
1 change: 1 addition & 0 deletions examples/isInViewport.js.map

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

86 changes: 86 additions & 0 deletions gulpfile.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
const gulp = require('gulp')
const rollup = require('rollup-stream')
const sourcemaps = require('gulp-sourcemaps')
const source = require('vinyl-source-stream')
const buffer = require('vinyl-buffer')
const rename = require('gulp-rename')
const uglify = require('gulp-uglify')
const mochaPhantomjs = require('gulp-mocha-phantomjs')
const buble = require('gulp-buble')
const del = require('del')
const pump = require('pump')
const eslint = require('gulp-eslint')


// clean build folder
gulp.task('clean', () => {
return del([
'lib/*'
])
})

// lint 'em files
gulp.task('lint', () => {
return gulp.src(['src/*.js', 'tests/*.js'])
.pipe(eslint())
.pipe(eslint.format())
.pipe(eslint.failAfterError())
})

// compile to es2015 but leave the import/exports intact
gulp.task('compile', ['lint'], () => {
return gulp.src('./src/index.js')
.pipe(sourcemaps.init())
.pipe(buble({
transforms: {
modules: false
}
}))
.pipe(rename('isInViewport.es6.js'))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest('lib'))
})

// bundle it
gulp.task('rollup', ['compile'], () => {
return rollup({
entry: './lib/isInViewport.es6.js',
format: 'umd',
moduleId: 'isInViewport',
moduleName: 'isInViewport',
globals: {
jquery: '$',
window: 'window'
},
external: ['jquery', 'window']
})
.pipe(source('isInViewport.es6.js', './lib'))
.pipe(buffer())
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(rename('isInViewport.js'))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest('lib'))
})

// minify it
gulp.task('minify', ['rollup'], (cb) => {
pump([
gulp.src('./lib/isInViewport.js'),
sourcemaps.init({loadMaps: true}),
uglify({
preserveComments: (_, {type, value: text}) => type === 'comment2' && /@(author|license)/g.test(text)
}),
rename('isInViewport.min.js'),
sourcemaps.write('.'),
gulp.dest('lib')
], cb)
})

// test the transpiled, minified bundle
gulp.task('test', ['minify'], () => {
return gulp.src('./tests/tests.html')
.pipe(mochaPhantomjs())
.on('error', () => gulp.start('clean')) // remove built files if tests fail
})

gulp.task('default', ['clean', 'test'])
Loading

0 comments on commit d5c0a65

Please sign in to comment.