From c784de0c1968eb36b2823789cd8c7f39d1d704b1 Mon Sep 17 00:00:00 2001 From: aashna27 Date: Sat, 11 May 2019 20:09:15 +0530 Subject: [PATCH] Added Eslint and husky (#1062) --- .eslintrc.js | 23 ++ Gruntfile.js | 56 ++-- examples/demo.js | 84 ++--- examples/images/IS-QR.js | 2 +- examples/images/test.gif.js | 2 +- examples/images/test.png.js | 2 +- examples/lib/cache.js | 10 +- examples/lib/defaultHtmlSequencerUi.js | 46 +-- examples/lib/defaultHtmlStepUi.js | 134 ++++---- examples/lib/insertPreview.js | 92 +++--- examples/lib/intermediateHtmlStepUi.js | 48 +-- examples/lib/mapHtmltypes.js | 36 +-- examples/lib/urlHash.js | 10 +- examples/sw.js | 2 +- index.js | 50 +-- package.json | 15 + spec/defaultHtmlSequencerUi.spec.js | 50 +-- spec/defaultHtmlStepUi.spec.js | 68 ++-- spec/insertPreview.spec.js | 28 +- spec/intermediateHtmlStepUi.spec.js | 18 +- spec/urlHash.spec.js | 42 +-- src/CliUtils.js | 28 +- src/ExportBin.js | 16 +- src/FormatInput.js | 82 ++--- src/ImageSequencer.js | 102 +++--- src/InsertStep.js | 4 +- src/Modules.js | 2 +- src/ReplaceImage.js | 8 +- src/Run.js | 34 +- src/RunToolkit.js | 14 +- src/Strings.js | 44 +-- src/cli/installModule.js | 26 +- src/cli/saveSequence.js | 8 +- src/cli/sequencerSteps.js | 34 +- src/modules/AddQR/Module.js | 84 ++--- src/modules/AddQR/QR.js | 82 ++--- src/modules/AddQR/index.js | 6 +- src/modules/Average/Module.js | 114 +++---- src/modules/Average/index.js | 6 +- src/modules/Blend/Module.js | 112 +++---- src/modules/Blend/index.js | 6 +- src/modules/Blur/Blur.js | 38 +-- src/modules/Blur/Module.js | 64 ++-- src/modules/Blur/index.js | 6 +- src/modules/Brightness/Module.js | 70 ++-- src/modules/Brightness/index.js | 6 +- src/modules/CanvasResize/Module.js | 90 +++--- src/modules/CanvasResize/index.js | 6 +- src/modules/Channel/Module.js | 10 +- src/modules/Channel/index.js | 6 +- src/modules/ColorTemperature/Module.js | 120 +++---- src/modules/ColorTemperature/index.js | 6 +- src/modules/Colorbar/index.js | 6 +- src/modules/Colormap/Colormap.js | 244 +++++++------- src/modules/Colormap/Module.js | 4 +- src/modules/Colormap/index.js | 6 +- src/modules/Contrast/Contrast.js | 70 ++-- src/modules/Contrast/Module.js | 62 ++-- src/modules/Contrast/index.js | 6 +- src/modules/Convolution/Convolution.js | 28 +- src/modules/Convolution/Module.js | 64 ++-- src/modules/Convolution/index.js | 6 +- src/modules/Crop/Crop.js | 8 +- src/modules/Crop/Module.js | 6 +- src/modules/Crop/Ui.js | 16 +- src/modules/Crop/index.js | 6 +- src/modules/DecodeQr/Module.js | 6 +- src/modules/DecodeQr/index.js | 6 +- src/modules/Dither/Dither.js | 8 +- src/modules/Dither/Module.js | 62 ++-- src/modules/Dither/index.js | 6 +- src/modules/DrawRectangle/DrawRectangle.js | 10 +- src/modules/DrawRectangle/Module.js | 64 ++-- src/modules/DrawRectangle/index.js | 6 +- src/modules/Dynamic/Module.js | 18 +- src/modules/Dynamic/index.js | 6 +- src/modules/EdgeDetect/EdgeUtils.js | 70 ++-- src/modules/EdgeDetect/Module.js | 8 +- src/modules/EdgeDetect/index.js | 6 +- src/modules/Exposure/Module.js | 70 ++-- src/modules/Exposure/index.js | 6 +- src/modules/FisheyeGl/Module.js | 8 +- src/modules/FisheyeGl/index.js | 6 +- src/modules/FlipImage/Module.js | 8 +- src/modules/FlipImage/flipImage.js | 12 +- src/modules/FlipImage/index.js | 6 +- src/modules/GammaCorrection/Module.js | 68 ++-- src/modules/GammaCorrection/index.js | 6 +- src/modules/Gradient/Module.js | 100 +++--- src/modules/Gradient/index.js | 6 +- src/modules/GridOverlay/GridOverlay.js | 46 +-- src/modules/GridOverlay/Module.js | 12 +- src/modules/GridOverlay/index.js | 6 +- src/modules/Histogram/Module.js | 146 ++++----- src/modules/Histogram/index.js | 6 +- src/modules/ImportImage/Module.js | 6 +- src/modules/ImportImage/Ui.js | 12 +- src/modules/ImportImage/index.js | 6 +- src/modules/Invert/Module.js | 10 +- src/modules/Ndvi/Module.js | 8 +- src/modules/Ndvi/Ui.js | 50 +-- src/modules/Ndvi/index.js | 6 +- src/modules/NdviColormap/Module.js | 16 +- src/modules/NdviColormap/index.js | 6 +- src/modules/Overlay/Module.js | 122 +++---- src/modules/Overlay/index.js | 6 +- src/modules/PaintBucket/Module.js | 58 ++-- src/modules/PaintBucket/PaintBucket.js | 26 +- src/modules/PaintBucket/index.js | 6 +- src/modules/ReplaceColor/Module.js | 66 ++-- src/modules/ReplaceColor/ReplaceColor.js | 66 ++-- src/modules/ReplaceColor/index.js | 6 +- src/modules/Resize/Module.js | 116 +++---- src/modules/Resize/index.js | 6 +- src/modules/Rotate/Module.js | 88 ++--- src/modules/Rotate/index.js | 6 +- src/modules/Saturation/Module.js | 6 +- src/modules/Saturation/index.js | 6 +- src/modules/TextOverlay/Module.js | 66 ++-- src/modules/TextOverlay/TextOverlay.js | 46 +-- src/modules/TextOverlay/index.js | 6 +- src/modules/Threshold/Module.js | 8 +- src/modules/Threshold/Threshold.js | 96 +++--- src/modules/Threshold/index.js | 6 +- src/modules/Tint/Module.js | 72 ++--- src/modules/Tint/index.js | 6 +- src/modules/WebglDistort/Module.js | 358 ++++++++++----------- src/modules/WebglDistort/glfx.js | 282 ++++++++-------- src/modules/WebglDistort/index.js | 6 +- src/modules/WhiteBalance/Module.js | 86 ++--- src/modules/WhiteBalance/index.js | 6 +- src/modules/_nomodule/PixelManipulation.js | 16 +- src/modules/_nomodule/gl-context.js | 56 ++-- src/modules/_nomodule/gpuUtils.js | 44 +-- src/ui/LoadImage.js | 12 +- src/ui/SetInputStep.js | 32 +- src/ui/UserInterface.js | 32 +- src/ui/prepareDynamic.js | 10 +- src/util/GetFormat.js | 6 +- src/util/ParseInputCoordinates.js | 42 +-- src/util/createMetaModule.js | 4 +- src/util/getDefaults.js | 2 +- src/util/getStep.js | 84 ++--- src/util/parseDistortCoordinates.js | 22 +- test/core/cli.js | 10 +- test/core/images/IS-QR.js | 2 +- test/core/images/test.gif.js | 2 +- test/core/images/test.png.js | 2 +- test/core/modules/add-qr.js | 2 +- test/core/modules/blend.js | 48 +-- test/core/modules/blur.js | 4 +- test/core/modules/brightness.js | 4 +- test/core/modules/canvas-resize.js | 30 +- test/core/modules/channel.js | 4 +- test/core/modules/color-temperature.js | 2 +- test/core/modules/colorbar.js | 2 +- test/core/modules/colormap.js | 4 +- test/core/modules/contrast.js | 4 +- test/core/modules/convolution.js | 2 +- test/core/modules/crop.js | 2 +- test/core/modules/decode-qr.js | 10 +- test/core/modules/dither.js | 4 +- test/core/modules/draw-rectangle.js | 2 +- test/core/modules/dynamic.js | 2 +- test/core/modules/edge-detect.js | 2 +- test/core/modules/exposure.js | 2 +- test/core/modules/fisheye-gl.js | 2 +- test/core/modules/gamma-correction.js | 2 +- test/core/modules/gradient.js | 2 +- test/core/modules/grid-overlay.js | 4 +- test/core/modules/histogram.js | 2 +- test/core/modules/invert.js | 50 +-- test/core/modules/ndvi-colormap.js | 2 +- test/core/modules/ndvi.js | 2 +- test/core/modules/overlay.js | 48 +-- test/core/modules/paint-bucket.js | 2 +- test/core/modules/replace-color.js | 10 +- test/core/modules/resize.js | 4 +- test/core/modules/rotate.js | 4 +- test/core/modules/saturation.js | 2 +- test/core/modules/text-overlay.js | 28 +- test/core/modules/threshold.js | 4 +- test/core/modules/tint.js | 2 +- test/core/modules/webgl-distort.js | 4 +- test/core/modules/white-balance.js | 2 +- test/core/sequencer/benchmark.js | 18 +- test/core/sequencer/chain.js | 34 +- test/core/sequencer/dynamic-imports.js | 4 +- test/core/sequencer/image-sequencer.js | 116 +++---- test/core/sequencer/import-export.js | 12 +- test/core/sequencer/meta-modules.js | 26 +- test/core/sequencer/replace.js | 22 +- test/core/sequencer/run.js | 22 +- test/core/templates/module-test.js | 48 +-- test/core/testModule/Module.js | 22 +- test/core/ui/user-interface.js | 38 +-- test/core/util/gpuUtils.js | 148 ++++----- test/core/util/parse-input.js | 18 +- test/spec/defaultHtmlSequencerUi.spec.js | 50 +-- test/spec/defaultHtmlStepUi.spec.js | 68 ++-- test/spec/insertPreview.spec.js | 28 +- test/spec/intermediateHtmlStepUi.spec.js | 18 +- test/spec/urlHash.spec.js | 42 +-- 203 files changed, 3288 insertions(+), 3250 deletions(-) create mode 100644 .eslintrc.js diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 00000000..0acedf0c --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,23 @@ +module.exports = { + 'env': { + 'browser': true, + 'commonjs': true, + 'es6': true, + 'node': true + }, + 'extends': 'eslint:recommended', + 'globals': { + 'Atomics': 'readonly', + 'SharedArrayBuffer': 'readonly' + }, + 'parserOptions': { + 'ecmaVersion': 2018 + }, + 'rules': { + 'indent': ['error',2], + 'linebreak-style': ['error','unix'], + 'quotes': ['error','single'], + 'semi': ['error','always'], + 'no-undef': 0 + } +}; \ No newline at end of file diff --git a/Gruntfile.js b/Gruntfile.js index 4e51e7d2..2880b207 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -1,76 +1,76 @@ module.exports = function(grunt) { - grunt.loadNpmTasks("grunt-browserify"); - grunt.loadNpmTasks("grunt-contrib-uglify-es"); - grunt.loadNpmTasks("grunt-browser-sync"); + grunt.loadNpmTasks('grunt-browserify'); + grunt.loadNpmTasks('grunt-contrib-uglify-es'); + grunt.loadNpmTasks('grunt-browser-sync'); - require("matchdep") - .filterDev("grunt-*") + require('matchdep') + .filterDev('grunt-*') .forEach(grunt.loadNpmTasks); grunt.initConfig({ - pkg: grunt.file.readJSON("package.json"), + pkg: grunt.file.readJSON('package.json'), watch: { options: { livereload: true }, source: { - files: ["src/**/*", "Gruntfile.js", "examples/lib/*", "examples/demo.js"], - tasks: ["compile"] + files: ['src/**/*', 'Gruntfile.js', 'examples/lib/*', 'examples/demo.js'], + tasks: ['compile'] } }, browserify: { core: { - src: ["src/ImageSequencer.js"], - dest: "dist/image-sequencer.js" + src: ['src/ImageSequencer.js'], + dest: 'dist/image-sequencer.js' }, ui: { - src: ["examples/demo.js"], - dest: "dist/image-sequencer-ui.js" + src: ['examples/demo.js'], + dest: 'dist/image-sequencer-ui.js' }, prodcore: { - src: ["src/ImageSequencer.js"], - dest: "dist/image-sequencer.brow.js" + src: ['src/ImageSequencer.js'], + dest: 'dist/image-sequencer.brow.js' }, produi: { - src: ["examples/demo.js"], - dest: "dist/image-sequencer-ui.brow.js" + src: ['examples/demo.js'], + dest: 'dist/image-sequencer-ui.brow.js' } }, uglify: { core: { - src: ["./dist/image-sequencer.js"], - dest: "./dist/image-sequencer.min.js" + src: ['./dist/image-sequencer.js'], + dest: './dist/image-sequencer.min.js' }, ui: { src: ['dist/image-sequencer-ui.js'], dest: 'dist/image-sequencer-ui.min.js' }, prodcore: { - src: ["dist/image-sequencer.brow.js"], - dest: "dist/image-sequencer.js" + src: ['dist/image-sequencer.brow.js'], + dest: 'dist/image-sequencer.js' }, produi: { - src: ["dist/image-sequencer-ui.brow.js"], - dest: "dist/image-sequencer-ui.js" + src: ['dist/image-sequencer-ui.brow.js'], + dest: 'dist/image-sequencer-ui.js' } }, browserSync: { dev: { options: { watchTask: true, - server: "./" + server: './' } } } }); /* Default (development): Watch files and build on change. */ - grunt.registerTask("default", ["watch"]); - grunt.registerTask("build", ["browserify:core", "browserify:ui", "uglify:core", "uglify:ui"]); - grunt.registerTask("serve", ["browserify:core", "browserify:ui", "browserSync", "watch"]); - grunt.registerTask("compile", ["browserify:core", "browserify:ui"]); - grunt.registerTask("production", ["browserify:prodcore", "browserify:produi", "uglify:prodcore", "uglify:produi"]); + grunt.registerTask('default', ['watch']); + grunt.registerTask('build', ['browserify:core', 'browserify:ui', 'uglify:core', 'uglify:ui']); + grunt.registerTask('serve', ['browserify:core', 'browserify:ui', 'browserSync', 'watch']); + grunt.registerTask('compile', ['browserify:core', 'browserify:ui']); + grunt.registerTask('production', ['browserify:prodcore', 'browserify:produi', 'uglify:prodcore', 'uglify:produi']); }; diff --git a/examples/demo.js b/examples/demo.js index f4ff07af..93d8b3a5 100644 --- a/examples/demo.js +++ b/examples/demo.js @@ -1,9 +1,9 @@ var defaultHtmlSequencerUi = require('./lib/defaultHtmlSequencerUi.js'), - setupCache = require('./lib/cache.js'), - intermediateHtmlStepUi = require('./lib/intermediateHtmlStepUi.js'), - DefaultHtmlStepUi = require('./lib/defaultHtmlStepUi.js'), - urlHash = require('./lib/urlHash.js'), - insertPreview = require('./lib/insertPreview.js'); + setupCache = require('./lib/cache.js'), + intermediateHtmlStepUi = require('./lib/intermediateHtmlStepUi.js'), + DefaultHtmlStepUi = require('./lib/defaultHtmlStepUi.js'), + urlHash = require('./lib/urlHash.js'), + insertPreview = require('./lib/insertPreview.js'); window.onload = function() { sequencer = ImageSequencer(); @@ -12,21 +12,21 @@ window.onload = function() { // Load information of all modules (Name, Inputs, Outputs) var modulesInfo = sequencer.modulesInfo(); - var addStepSelect = $("#addStep select"); - addStepSelect.html(""); + var addStepSelect = $('#addStep select'); + addStepSelect.html(''); // Add modules to the addStep dropdown for (var m in modulesInfo) { if (modulesInfo[m] && modulesInfo[m].name) addStepSelect.append( - '" + '' ); } // Null option addStepSelect.append(''); addStepSelect.selectize({ sortField: 'text' - }); + }); } refreshOptions(); @@ -36,7 +36,7 @@ window.onload = function() { var shouldDisplay = $('body').scrollTop() > 20 || $(':root').scrollTop() > 20; $('#move-up').css({ - display: shouldDisplay ? 'block' : 'none' + display: shouldDisplay ? 'block' : 'none' }); } @@ -46,7 +46,7 @@ window.onload = function() { $(':root').animate({scrollTop: 0}); } - $('#move-up').on("click",topFunction); + $('#move-up').on('click',topFunction); // UI for each step: @@ -59,48 +59,48 @@ window.onload = function() { if (urlHash.getUrlHashParameter('src')) { sequencer.loadImage(urlHash.getUrlHashParameter('src'), ui.onLoad); } else { - sequencer.loadImage("images/tulips.png", ui.onLoad); + sequencer.loadImage('images/tulips.png', ui.onLoad); } var resetSequence = function(){ - var r=confirm("Do you want to reset the sequence?"); + var r=confirm('Do you want to reset the sequence?'); if (r) - window.location = "/"; - } + window.location = '/'; + }; - $("#addStep select").on("change", ui.selectNewStepUi); - $("#addStep #add-step-btn").on("click", ui.addStepUi); - $("#resetButton").on("click",resetSequence); + $('#addStep select').on('change', ui.selectNewStepUi); + $('#addStep #add-step-btn').on('click', ui.addStepUi); + $('#resetButton').on('click',resetSequence); //Module button radio selection - $('.radio-group .radio').on("click", function() { + $('.radio-group .radio').on('click', function() { $(this).parent().find('.radio').removeClass('selected'); $(this).addClass('selected'); newStep = $(this).attr('data-value'); //$("#addStep option[value=" + newStep + "]").attr('selected', 'selected'); - $("#addStep select").val(newStep); + $('#addStep select').val(newStep); ui.selectNewStepUi(newStep); ui.addStepUi(newStep); $(this).removeClass('selected'); }); $('#download-btn').click(function() { - $('.step-thumbnail:last()').trigger("click"); + $('.step-thumbnail:last()').trigger('click'); return false; }); function displayMessageOnSaveSequence(){ - $(".savesequencemsg").fadeIn(); - setTimeout(function() { - $(".savesequencemsg").fadeOut(); - }, 1000); - } + $('.savesequencemsg').fadeIn(); + setTimeout(function() { + $('.savesequencemsg').fadeOut(); + }, 1000); + } $('body').on('click', 'button.remove', ui.removeStepUi); $('#save-seq').click(() => { - var result = window.prompt("Please give a name to your sequence... (Saved sequence will only be available in this browser)."); + var result = window.prompt('Please give a name to your sequence... (Saved sequence will only be available in this browser).'); if(result){ - result = result + " (local)"; + result = result + ' (local)'; sequencer.saveSequence(result, sequencer.toString()); sequencer.loadModules(); displayMessageOnSaveSequence(); @@ -118,11 +118,11 @@ window.onload = function() { var button = event.target; button.disabled = true; - button.innerHTML='' + button.innerHTML=''; try { // Select all images from previous steps - var imgs = document.getElementsByClassName("step-thumbnail"); + var imgs = document.getElementsByClassName('step-thumbnail'); var imgSrcs = []; @@ -135,7 +135,7 @@ window.onload = function() { 'gifHeight': imgs[0].height, 'images': imgSrcs, 'frameDuration': 7, - } + }; gifshot.createGIF(options, function(obj) { if (!obj.error) { @@ -143,21 +143,21 @@ window.onload = function() { var image = obj.image; var animatedImage = document.createElement('img'); - animatedImage.id = "gif_element"; + animatedImage.id = 'gif_element'; animatedImage.src = image; var modal = $('#js-download-gif-modal'); - $("#js-download-as-gif-button").one("click", function() { + $('#js-download-as-gif-button').one('click', function() { // Trigger download - download(image, "index.gif", "image/gif"); + download(image, 'index.gif', 'image/gif'); // Close modal modal.modal('hide'); - }) + }); - var gifContainer = document.getElementById("js-download-modal-gif-container"); + var gifContainer = document.getElementById('js-download-modal-gif-container'); // Clear previous results gifContainer.innerHTML = ''; @@ -186,16 +186,16 @@ window.onload = function() { // image selection and drag/drop handling from examples/lib/imageSelection.js sequencer.setInputStep({ - dropZoneSelector: "#dropzone", - fileInputSelector: "#fileInput", - takePhotoSelector: "#take-photo", + dropZoneSelector: '#dropzone', + fileInputSelector: '#fileInput', + takePhotoSelector: '#take-photo', onLoad: function onFileReaderLoad(progress) { var reader = progress.target; var step = sequencer.steps[0]; var util= intermediateHtmlStepUi(sequencer); step.output.src = reader.result; sequencer.run({ index: 0 }); - if(typeof step.options !=="undefined") + if(typeof step.options !=='undefined') step.options.step.imgElement.src = reader.result; else step.imgElement.src = reader.result; @@ -206,7 +206,7 @@ window.onload = function() { var step = sequencer.steps[0]; step.output.src = url; sequencer.run({ index: 0 }); - if(typeof step.options !=="undefined") + if(typeof step.options !=='undefined') step.options.step.imgElement.src = url; else step.imgElement.src = url; @@ -220,6 +220,6 @@ window.onload = function() { if (urlHash.getUrlHashParameter('src')) { insertPreview.updatePreviews(urlHash.getUrlHashParameter('src'),'#addStep'); } else { - insertPreview.updatePreviews("images/tulips.png",'#addStep'); + insertPreview.updatePreviews('images/tulips.png','#addStep'); } }; diff --git a/examples/images/IS-QR.js b/examples/images/IS-QR.js index 5e01ceae..3e3269ed 100644 --- a/examples/images/IS-QR.js +++ b/examples/images/IS-QR.js @@ -1 +1 @@ -module.exports = ""; +module.exports = ''; diff --git a/examples/images/test.gif.js b/examples/images/test.gif.js index fce3817e..0e6c03ff 100644 --- a/examples/images/test.gif.js +++ b/examples/images/test.gif.js @@ -1 +1 @@ -module.exports = ""; +module.exports = ''; diff --git a/examples/images/test.png.js b/examples/images/test.png.js index d0d6126c..de221ae9 100644 --- a/examples/images/test.png.js +++ b/examples/images/test.png.js @@ -1 +1 @@ -module.exports = ""; +module.exports = ''; diff --git a/examples/lib/cache.js b/examples/lib/cache.js index 807ad062..cec27dec 100644 --- a/examples/lib/cache.js +++ b/examples/lib/cache.js @@ -4,11 +4,11 @@ var setupCache = function() { .then(function(registration) { const installingWorker = registration.installing; installingWorker.onstatechange = () => { - console.log(installingWorker) + console.log(installingWorker); if (installingWorker.state === 'installed') { location.reload(); } - } + }; console.log('Registration successful, scope is:', registration.scope); }) .catch(function(error) { @@ -19,12 +19,12 @@ var setupCache = function() { if ('serviceWorker' in navigator) { caches.keys().then(function(cacheNames) { cacheNames.forEach(function(cacheName) { - $("#clear-cache").append(" " + cacheName); + $('#clear-cache').append(' ' + cacheName); }); }); } - $("#clear-cache").click(function() { + $('#clear-cache').click(function() { if ('serviceWorker' in navigator) { caches.keys().then(function(cacheNames) { cacheNames.forEach(function(cacheName) { @@ -34,6 +34,6 @@ var setupCache = function() { } location.reload(); }); -} +}; module.exports = setupCache; diff --git a/examples/lib/defaultHtmlSequencerUi.js b/examples/lib/defaultHtmlSequencerUi.js index 217fcf84..cb536cfb 100644 --- a/examples/lib/defaultHtmlSequencerUi.js +++ b/examples/lib/defaultHtmlSequencerUi.js @@ -2,50 +2,50 @@ var urlHash = require('./urlHash.js'); function DefaultHtmlSequencerUi(_sequencer, options) { options = options || {}; - var addStepSel = options.addStepSel = options.addStepSel || "#addStep"; - var removeStepSel = options.removeStepSel = options.removeStepSel || "button.remove"; - var selectStepSel = options.selectStepSel = options.selectStepSel || "#selectStep"; + var addStepSel = options.addStepSel = options.addStepSel || '#addStep'; + var removeStepSel = options.removeStepSel = options.removeStepSel || 'button.remove'; + var selectStepSel = options.selectStepSel = options.selectStepSel || '#selectStep'; function onLoad() { importStepsFromUrlHash(); if ($('#selectStep').val()==='none') - $(addStepSel + " #add-step-btn").prop("disabled", true); - handleSaveSequence(); + $(addStepSel + ' #add-step-btn').prop('disabled', true); + handleSaveSequence(); } // look up needed steps from Url Hash: function importStepsFromUrlHash() { - var hash = urlHash.getUrlHashParameter("steps"); + var hash = urlHash.getUrlHashParameter('steps'); if (hash) { _sequencer.importString(hash); _sequencer.run({ index: 0 }); } - urlHash.setUrlHashParameter("steps", sequencer.toString()); + urlHash.setUrlHashParameter('steps', sequencer.toString()); } function selectNewStepUi() { - var m = $(addStepSel + " select").val(); + var m = $(addStepSel + ' select').val(); if(!m) m = arguments[0]; - $(addStepSel + " .info").html(_sequencer.modulesInfo(m).description); - $(addStepSel + " #add-step-btn").prop("disabled", false); + $(addStepSel + ' .info').html(_sequencer.modulesInfo(m).description); + $(addStepSel + ' #add-step-btn').prop('disabled', false); } function removeStepUi() { var index = $(removeStepSel).index(this) + 1; sequencer.removeSteps(index).run({ index: index - 1 }); // remove from URL hash too - urlHash.setUrlHashParameter("steps", sequencer.toString()); + urlHash.setUrlHashParameter('steps', sequencer.toString()); //disable save-sequence button if all steps are removed handleSaveSequence(); } function addStepUi() { - if ($(addStepSel + " select").val() == "none") return; + if ($(addStepSel + ' select').val() == 'none') return; var newStepName; - if(typeof arguments[0] !== "string") - newStepName = $(addStepSel + " select option").html().toLowerCase(); - else newStepName = arguments[0] + if(typeof arguments[0] !== 'string') + newStepName = $(addStepSel + ' select option').html().toLowerCase(); + else newStepName = arguments[0]; /* @@ -56,28 +56,28 @@ function DefaultHtmlSequencerUi(_sequencer, options) { var sequenceLength = 1; if (sequencer.sequences[newStepName]) { sequenceLength = sequencer.sequences[newStepName].length; - } else if (sequencer.modules[newStepName][1]["length"]) { - sequenceLength = sequencer.modules[newStepName][1]["length"]; + } else if (sequencer.modules[newStepName][1]['length']) { + sequenceLength = sequencer.modules[newStepName][1]['length']; } _sequencer .addSteps(newStepName, options) .run({ index: _sequencer.steps.length - sequenceLength - 1 }); - $(addStepSel + " .info").html("Select a new module to add to your sequence."); - $(addStepSel + " select").val("none"); + $(addStepSel + ' .info').html('Select a new module to add to your sequence.'); + $(addStepSel + ' select').val('none'); //enable save-sequence button if disabled initially handleSaveSequence(); // add to URL hash too - urlHash.setUrlHashParameter("steps", _sequencer.toString()) + urlHash.setUrlHashParameter('steps', _sequencer.toString()); } function handleSaveSequence(){ var stepCount=sequencer.steps.length; if(stepCount<2) - $(" #save-seq").prop("disabled", true); + $(' #save-seq').prop('disabled', true); else - $(" #save-seq").prop("disabled", false); + $(' #save-seq').prop('disabled', false); } return { @@ -86,7 +86,7 @@ function DefaultHtmlSequencerUi(_sequencer, options) { selectNewStepUi: selectNewStepUi, removeStepUi: removeStepUi, addStepUi: addStepUi - } + }; } module.exports = DefaultHtmlSequencerUi; diff --git a/examples/lib/defaultHtmlStepUi.js b/examples/lib/defaultHtmlStepUi.js index 679b545e..d3b1fd7c 100644 --- a/examples/lib/defaultHtmlStepUi.js +++ b/examples/lib/defaultHtmlStepUi.js @@ -16,8 +16,8 @@ var mapHtmlTypes = require('./mapHtmltypes'); function DefaultHtmlStepUi(_sequencer, options) { options = options || {}; - var stepsEl = options.stepsEl || document.querySelector("#steps"); - var selectStepSel = options.selectStepSel = options.selectStepSel || "#selectStep"; + var stepsEl = options.stepsEl || document.querySelector('#steps'); + var selectStepSel = options.selectStepSel = options.selectStepSel || '#selectStep'; function onSetup(step, stepOptions) { if (step.options && step.options.description) @@ -39,7 +39,7 @@ function DefaultHtmlStepUi(_sequencer, options) {
\
\

' + - '' + (step.description || "") + '' + + '' + (step.description || '') + '' + '

\
\
\ @@ -65,10 +65,10 @@ function DefaultHtmlStepUi(_sequencer, options) { var util = intermediateHtmlStepUi(_sequencer, step); var parser = new DOMParser(); - step.ui = parser.parseFromString(step.ui, "text/html"); - step.ui = step.ui.querySelector("div.container-fluid"); - step.linkElements = step.ui.querySelectorAll("a"); - step.imgElement = step.ui.querySelector("a img.img-thumbnail"); + step.ui = parser.parseFromString(step.ui, 'text/html'); + step.ui = step.ui.querySelector('div.container-fluid'); + step.linkElements = step.ui.querySelectorAll('a'); + step.imgElement = step.ui.querySelector('a img.img-thumbnail'); if (_sequencer.modulesInfo().hasOwnProperty(step.name)) { var inputs = _sequencer.modulesInfo(step.name).inputs; @@ -77,16 +77,16 @@ function DefaultHtmlStepUi(_sequencer, options) { for (var paramName in merged) { var isInput = inputs.hasOwnProperty(paramName); - var html = ""; + var html = ''; var inputDesc = isInput ? mapHtmlTypes(inputs[paramName]) : {}; if (!isInput) { html += ''; - } else if (inputDesc.type.toLowerCase() == "select") { + } else if (inputDesc.type.toLowerCase() == 'select') { html += '"; + html += ''; } else { let paramVal = step.options[paramName] || inputDesc.default; html = @@ -97,9 +97,9 @@ function DefaultHtmlStepUi(_sequencer, options) { '" value="' + paramVal + '" placeholder ="' + - (inputDesc.placeholder || ""); + (inputDesc.placeholder || ''); - if (inputDesc.type.toLowerCase() == "range") { + if (inputDesc.type.toLowerCase() == 'range') { html += '"min="' + inputDesc.min + @@ -112,76 +112,76 @@ function DefaultHtmlStepUi(_sequencer, options) { else html += '">'; } - var div = document.createElement("div"); - div.className = "row"; - div.setAttribute("name", paramName); + var div = document.createElement('div'); + div.className = 'row'; + div.setAttribute('name', paramName); var description = inputs[paramName].desc || paramName; div.innerHTML = - "
\ - \ + ' + html + - "\ -
"; - step.ui.querySelector("div.details").appendChild(div); + '\ +
'; + step.ui.querySelector('div.details').appendChild(div); } - $(step.ui.querySelector("div.panel-footer")).append( + $(step.ui.querySelector('div.panel-footer')).append( '
Press apply to see changes
' ); - $(step.ui.querySelector("div.panel-footer")).prepend( + $(step.ui.querySelector('div.panel-footer')).prepend( '' ); } - if (step.name != "load-image") { + if (step.name != 'load-image') { step.ui - .querySelector("div.trash-container") + .querySelector('div.trash-container') .prepend( - parser.parseFromString(tools, "text/html").querySelector("div") + parser.parseFromString(tools, 'text/html').querySelector('div') ); - $(step.ui.querySelectorAll(".remove")).on('click', function() {notify('Step Removed','remove-notification')}); - $(step.ui.querySelectorAll(".insert-step")).on('click', function() { util.insertStep(step.ID) }); + $(step.ui.querySelectorAll('.remove')).on('click', function() {notify('Step Removed','remove-notification');}); + $(step.ui.querySelectorAll('.insert-step')).on('click', function() { util.insertStep(step.ID); }); // Insert the step's UI in the right place if (stepOptions.index == _sequencer.steps.length) { stepsEl.appendChild(step.ui); - $("#steps .step-container:nth-last-child(1) .insert-step").prop('disabled',true); - if($("#steps .step-container:nth-last-child(2)")) - $("#steps .step-container:nth-last-child(2) .insert-step").prop('disabled',false); + $('#steps .step-container:nth-last-child(1) .insert-step').prop('disabled',true); + if($('#steps .step-container:nth-last-child(2)')) + $('#steps .step-container:nth-last-child(2) .insert-step').prop('disabled',false); } else { stepsEl.insertBefore(step.ui, $(stepsEl).children()[stepOptions.index]); } } else { - $("#load-image").append(step.ui); + $('#load-image').append(step.ui); } - $(step.ui.querySelector(".toggle")).on("click", () => { + $(step.ui.querySelector('.toggle')).on('click', () => { $(step.ui.querySelector('.toggleIcon')).toggleClass('rotated'); - $(step.ui.querySelectorAll(".cal")).collapse('toggle'); + $(step.ui.querySelectorAll('.cal')).collapse('toggle'); }); - $(step.imgElement).on("mousemove", _.debounce(() => imageHover(step), 150)); + $(step.imgElement).on('mousemove', _.debounce(() => imageHover(step), 150)); function saveOptions(e) { e.preventDefault(); if (optionsChanged){ - $(step.ui.querySelector("div.details")) - .find("input,select") + $(step.ui.querySelector('div.details')) + .find('input,select') .each(function(i, input) { $(input) .data('initValue', $(input).val()) .data('hasChangedBefore', false); - step.options[$(input).attr("name")] = $(input).val(); + step.options[$(input).attr('name')] = $(input).val(); }); _sequencer.run({ index: step.index - 1 }); // modify the url hash - urlHash.setUrlHashParameter("steps", _sequencer.toString()) + urlHash.setUrlHashParameter('steps', _sequencer.toString()); // disable the save button $(step.ui.querySelector('.btn-save')).prop('disabled', true); optionsChanged = false; @@ -214,32 +214,32 @@ function DefaultHtmlStepUi(_sequencer, options) { $(this).val(), $(this).data('initValue'), $(this).data('hasChangedBefore') - ) - ) - }) - }) + ) + ); + }); + }); $('input[type="range"]').on('input', function() { - $(this).next().html($(this).val()); - }) + $(this).next().html($(this).val()); + }); } function onDraw(step) { - $(step.ui.querySelector(".load")).show(); - $(step.ui.querySelector("img")).hide(); - $(step.ui.querySelectorAll(".load-spin")).show(); + $(step.ui.querySelector('.load')).show(); + $(step.ui.querySelector('img')).hide(); + $(step.ui.querySelectorAll('.load-spin')).show(); } function onComplete(step) { - $(step.ui.querySelector("img")).show(); - $(step.ui.querySelectorAll(".load-spin")).hide(); - $(step.ui.querySelector(".load")).hide(); + $(step.ui.querySelector('img')).show(); + $(step.ui.querySelectorAll('.load-spin')).hide(); + $(step.ui.querySelector('.load')).hide(); - step.imgElement.src = (step.name == "load-image") ? step.output.src : step.output; - var imgthumbnail = step.ui.querySelector(".img-thumbnail"); + step.imgElement.src = (step.name == 'load-image') ? step.output.src : step.output; + var imgthumbnail = step.ui.querySelector('.img-thumbnail'); for (let index = 0; index < step.linkElements.length; index++) { if (step.linkElements[index].contains(imgthumbnail)) step.linkElements[index].href = step.imgElement.src; @@ -247,13 +247,13 @@ function DefaultHtmlStepUi(_sequencer, options) { // TODO: use a generalized version of this function fileExtension(output) { - return output.split("/")[1].split(";")[0]; + return output.split('/')[1].split(';')[0]; } for (let index = 0; index < step.linkElements.length; index++) { - step.linkElements[index].download = step.name + "." + fileExtension(step.imgElement.src); - step.linkElements[index].target = "_blank"; + step.linkElements[index].download = step.name + '.' + fileExtension(step.imgElement.src); + step.linkElements[index].target = '_blank'; } // fill inputs with stored step options @@ -262,11 +262,11 @@ function DefaultHtmlStepUi(_sequencer, options) { var outputs = _sequencer.modulesInfo(step.name).outputs; for (var i in inputs) { if (step.options[i] !== undefined) { - if (inputs[i].type.toLowerCase() === "input") + if (inputs[i].type.toLowerCase() === 'input') $(step.ui.querySelector('div[name="' + i + '"] input')) .val(step.options[i]) .data('initValue', step.options[i]); - if (inputs[i].type.toLowerCase() === "select") + if (inputs[i].type.toLowerCase() === 'select') $(step.ui.querySelector('div[name="' + i + '"] select')) .val(step.options[i]) .data('initValue', step.options[i]); @@ -295,13 +295,13 @@ function DefaultHtmlStepUi(_sequencer, options) { var xPos = e.pageX - offset.left; var yPos = e.pageY - offset.top; var myData = context.getImageData(xPos, yPos, 1, 1); - img[0].title = "rgb: " +myData.data[0]+","+ myData.data[1]+","+myData.data[2];//+ rgbdata; + img[0].title = 'rgb: ' +myData.data[0]+','+ myData.data[1]+','+myData.data[2];//+ rgbdata; }); } function onRemove(step) { step.ui.remove(); - $("#steps .step-container:nth-last-child(1) .insert-step").prop('disabled',true); + $('#steps .step-container:nth-last-child(1) .insert-step').prop('disabled',true); $('div[class*=imgareaselect-]').remove(); } @@ -314,7 +314,7 @@ function DefaultHtmlStepUi(_sequencer, options) { var notification = document.createElement('span'); notification.innerHTML = ' ' + msg ; notification.id = id; - notification.classList.add("notification"); + notification.classList.add('notification'); $('body').append(notification); } @@ -331,13 +331,13 @@ function DefaultHtmlStepUi(_sequencer, options) { onDraw: onDraw, notify: notify, imageHover: imageHover - } + }; } -if(typeof window === "undefined"){ +if(typeof window === 'undefined'){ module.exports={ DefaultHtmlStepUi: DefaultHtmlStepUi - } + }; } module.exports = DefaultHtmlStepUi; diff --git a/examples/lib/insertPreview.js b/examples/lib/insertPreview.js index afb40a6f..2eab5f03 100644 --- a/examples/lib/insertPreview.js +++ b/examples/lib/insertPreview.js @@ -1,55 +1,55 @@ function generatePreview(previewStepName, customValues, path, selector) { - var previewSequencer = ImageSequencer(); - function insertPreview(src) { - var img = document.createElement('img'); - img.classList.add('img-thumbnail') - img.classList.add('no-border'); - img.src = src; - $(img).css("max-width", "200%"); - $(img).css("transform", "translateX(-20%)"); - $(selector + ' .radio-group').find('div').each(function() { - if ($(this).find('div').attr('data-value') === previewStepName) { - $(this).find('div').append(img); - } - }); - } - - function loadPreview() { - if (previewStepName === "crop") { - previewSequencer.addSteps(previewStepName, customValues).run(insertPreview); + var previewSequencer = ImageSequencer(); + function insertPreview(src) { + var img = document.createElement('img'); + img.classList.add('img-thumbnail'); + img.classList.add('no-border'); + img.src = src; + $(img).css('max-width', '200%'); + $(img).css('transform', 'translateX(-20%)'); + $(selector + ' .radio-group').find('div').each(function() { + if ($(this).find('div').attr('data-value') === previewStepName) { + $(this).find('div').append(img); } - else { - previewSequencer.addSteps(previewStepName, { [previewStepName]: customValues }).run(insertPreview); - } - } - previewSequencer.loadImage(path, loadPreview); - } - - function updatePreviews(src, selector) { - $(selector+' img').remove(); - - var previewSequencerSteps = { - "resize": "125%", - "brightness": "175", - "saturation": "0.5", - "rotate": 90, - "contrast": 90, - "crop": { - "x": 0, - "y": 0, - "w": "(50%)", - "h": "(50%)", - "noUI": true - } - } - - Object.keys(previewSequencerSteps).forEach(function (step, index) { - generatePreview(step, Object.values(previewSequencerSteps)[index], src, selector); }); } + function loadPreview() { + if (previewStepName === 'crop') { + previewSequencer.addSteps(previewStepName, customValues).run(insertPreview); + } + else { + previewSequencer.addSteps(previewStepName, { [previewStepName]: customValues }).run(insertPreview); + } + } + previewSequencer.loadImage(path, loadPreview); +} + +function updatePreviews(src, selector) { + $(selector+' img').remove(); + + var previewSequencerSteps = { + 'resize': '125%', + 'brightness': '175', + 'saturation': '0.5', + 'rotate': 90, + 'contrast': 90, + 'crop': { + 'x': 0, + 'y': 0, + 'w': '(50%)', + 'h': '(50%)', + 'noUI': true + } + }; + + Object.keys(previewSequencerSteps).forEach(function (step, index) { + generatePreview(step, Object.values(previewSequencerSteps)[index], src, selector); + }); +} + module.exports = { generatePreview : generatePreview, updatePreviews : updatePreviews -} +}; diff --git a/examples/lib/intermediateHtmlStepUi.js b/examples/lib/intermediateHtmlStepUi.js index bdfa09ab..ea2a36ee 100644 --- a/examples/lib/intermediateHtmlStepUi.js +++ b/examples/lib/intermediateHtmlStepUi.js @@ -1,5 +1,5 @@ var urlHash = require('./urlHash.js'), - insertPreview = require('./insertPreview.js'); + insertPreview = require('./insertPreview.js'); function IntermediateHtmlStepUi(_sequencer, step, options) { function stepUI() { @@ -66,52 +66,52 @@ function IntermediateHtmlStepUi(_sequencer, step, options) { function selectNewStepUi() { - var insertSelect = $(step.ui.querySelector('.insert-step-select')) + var insertSelect = $(step.ui.querySelector('.insert-step-select')); var m = insertSelect.val(); $(step.ui.querySelector('.insertDiv .info')).html(_sequencer.modulesInfo(m).description); - $(step.ui.querySelector('.insertDiv .add-step-btn')).prop("disabled", false); + $(step.ui.querySelector('.insertDiv .add-step-btn')).prop('disabled', false); } var toggleDiv = function(callback = function(){}){ $(step.ui.querySelector('.insertDiv')).collapse('toggle'); - if ($(step.ui.querySelector('.insert-text')).css('display') != "none"){ - $(step.ui.querySelector('.insert-text')).fadeToggle(200, function(){$(step.ui.querySelector('.no-insert-text')).fadeToggle(200, callback)}) + if ($(step.ui.querySelector('.insert-text')).css('display') != 'none'){ + $(step.ui.querySelector('.insert-text')).fadeToggle(200, function(){$(step.ui.querySelector('.no-insert-text')).fadeToggle(200, callback);}); } else { - $(step.ui.querySelector('.no-insert-text')).fadeToggle(200, function(){$(step.ui.querySelector('.insert-text')).fadeToggle(200, callback)}) + $(step.ui.querySelector('.no-insert-text')).fadeToggle(200, function(){$(step.ui.querySelector('.insert-text')).fadeToggle(200, callback);}); } - } + }; insertStep = function (id) { var modulesInfo = _sequencer.modulesInfo(); var parser = new DOMParser(); var addStepUI = stepUI(); - addStepUI = parser.parseFromString(addStepUI, "text/html").querySelector("div") + addStepUI = parser.parseFromString(addStepUI, 'text/html').querySelector('div'); if ($(step.ui.querySelector('.insertDiv')).length > 0){ toggleDiv(); } else { step.ui - .querySelector("div.step") - .insertAdjacentElement('afterend', - addStepUI - ); + .querySelector('div.step') + .insertAdjacentElement('afterend', + addStepUI + ); toggleDiv(function(){ insertPreview.updatePreviews(step.output, '.insertDiv'); }); } - $(step.ui.querySelector('.insertDiv .close-insert-box')).off('click').on('click', function(){toggleDiv(function(){})}); + $(step.ui.querySelector('.insertDiv .close-insert-box')).off('click').on('click', function(){toggleDiv(function(){});}); var insertStepSelect = $(step.ui.querySelector('.insert-step-select')); - insertStepSelect.html(""); + insertStepSelect.html(''); // Add modules to the insertStep dropdown for (var m in modulesInfo) { if (modulesInfo[m] !== undefined) insertStepSelect.append( - '" + '' ); } insertStepSelect.selectize({ @@ -120,7 +120,7 @@ function IntermediateHtmlStepUi(_sequencer, step, options) { $(step.ui.querySelector('.inserDiv .add-step-btn')).prop('disabled', true); insertStepSelect.append(''); - $(step.ui.querySelector('.insertDiv .radio-group .radio')).on("click", function () { + $(step.ui.querySelector('.insertDiv .radio-group .radio')).on('click', function () { $(this).parent().find('.radio').removeClass('selected'); $(this).addClass('selected'); newStep = $(this).attr('data-value'); @@ -130,34 +130,34 @@ function IntermediateHtmlStepUi(_sequencer, step, options) { $(this).removeClass('selected'); }); insertStepSelect.on('change', selectNewStepUi); - $(step.ui.querySelector('.insertDiv .add-step-btn')).on('click', function () { insert(id) }); - } + $(step.ui.querySelector('.insertDiv .add-step-btn')).on('click', function () { insert(id); }); + }; function insert(id) { options = options || {}; var insertStepSelect = $(step.ui.querySelector('.insert-step-select')); - if (insertStepSelect.val() == "none") return; + if (insertStepSelect.val() == 'none') return; - var newStepName = insertStepSelect.val() + var newStepName = insertStepSelect.val(); toggleDiv(); var sequenceLength = 1; if (sequencer.sequences[newStepName]) { sequenceLength = sequencer.sequences[newStepName].length; - } else if (sequencer.modules[newStepName][1]["length"]) { - sequenceLength = sequencer.modules[newStepName][1]["length"]; + } else if (sequencer.modules[newStepName][1]['length']) { + sequenceLength = sequencer.modules[newStepName][1]['length']; } _sequencer .insertSteps(id + 1, newStepName).run({ index: id }); // add to URL hash too - urlHash.setUrlHashParameter("steps", _sequencer.toString()); + urlHash.setUrlHashParameter('steps', _sequencer.toString()); } return { insertStep - } + }; } module.exports = IntermediateHtmlStepUi; diff --git a/examples/lib/mapHtmltypes.js b/examples/lib/mapHtmltypes.js index 1eac09a7..f0cffe09 100644 --- a/examples/lib/mapHtmltypes.js +++ b/examples/lib/mapHtmltypes.js @@ -1,24 +1,24 @@ function mapHtmlTypes(inputInfo){ var htmlType; switch(inputInfo.type.toLowerCase()){ - case 'integer': - htmlType = inputInfo.min != undefined ? 'range' : 'number'; - break; - case 'string': - htmlType = 'text'; - break; - case 'select': - htmlType = 'select'; - break; - case 'percentage': - htmlType = 'number'; - break; - case 'float': - htmlType = inputInfo.min != undefined ? 'range' : 'text'; - break; - default: - htmlType = 'text'; - break; + case 'integer': + htmlType = inputInfo.min != undefined ? 'range' : 'number'; + break; + case 'string': + htmlType = 'text'; + break; + case 'select': + htmlType = 'select'; + break; + case 'percentage': + htmlType = 'number'; + break; + case 'float': + htmlType = inputInfo.min != undefined ? 'range' : 'text'; + break; + default: + htmlType = 'text'; + break; } var response = inputInfo; response.type = htmlType; diff --git a/examples/lib/urlHash.js b/examples/lib/urlHash.js index 3d48e7c2..d19f56b9 100644 --- a/examples/lib/urlHash.js +++ b/examples/lib/urlHash.js @@ -42,8 +42,8 @@ function setUrlHashParameter(param, value) { } module.exports = { - getUrlHashParameter: getUrlHashParameter, - setUrlHashParameter: setUrlHashParameter, - getUrlHashParameters: getUrlHashParameters, - setUrlHashParameters: setUrlHashParameters - } + getUrlHashParameter: getUrlHashParameter, + setUrlHashParameter: setUrlHashParameter, + getUrlHashParameters: getUrlHashParameters, + setUrlHashParameters: setUrlHashParameters +}; diff --git a/examples/sw.js b/examples/sw.js index 1e5cc66f..3280a768 100644 --- a/examples/sw.js +++ b/examples/sw.js @@ -25,7 +25,7 @@ self.addEventListener('fetch', function(event) { caches.open(staticCacheName).then(function(cache) { return cache.match(event.request).then(function (response) { return response || fetch(event.request).then(function(response) { - if(event.request.method == "GET") + if(event.request.method == 'GET') cache.put(event.request, response.clone()); return response; }); diff --git a/index.js b/index.js index 8164fb28..8992c854 100755 --- a/index.js +++ b/index.js @@ -2,13 +2,13 @@ require('./src/ImageSequencer'); sequencer = ImageSequencer({ ui: false }); -var fs = require('fs') +var fs = require('fs'); var program = require('commander'); -var utils = require('./src/CliUtils') +var utils = require('./src/CliUtils'); -var saveSequence = require('./src/cli/saveSequence.js') -var installModule = require('./src/cli/installModule.js') -var sequencerSteps = require('./src/cli/sequencerSteps.js') +var saveSequence = require('./src/cli/saveSequence.js'); +var installModule = require('./src/cli/installModule.js'); +var sequencerSteps = require('./src/cli/sequencerSteps.js'); function exit(message) { console.error(message); @@ -16,39 +16,39 @@ function exit(message) { } program - .version("0.1.0") - .option("-i, --image [PATH/URL]", "Input image URL") - .option("-s, --step [step-name]", "Name of the step to be added.") - .option("-o, --output [PATH]", "Directory where output will be stored.") - .option("-b, --basic", "Basic mode outputs only final image") - .option("-c, --config [Object]", "Options for the step") - .option("--save-sequence [string]", "Name space separated with Stringified sequence") - .option('--install-module [string]', "Module name space seaprated npm package name") + .version('0.1.0') + .option('-i, --image [PATH/URL]', 'Input image URL') + .option('-s, --step [step-name]', 'Name of the step to be added.') + .option('-o, --output [PATH]', 'Directory where output will be stored.') + .option('-b, --basic', 'Basic mode outputs only final image') + .option('-c, --config [Object]', 'Options for the step') + .option('--save-sequence [string]', 'Name space separated with Stringified sequence') + .option('--install-module [string]', 'Module name space seaprated npm package name') .parse(process.argv); -if (program.saveSequence) saveSequence(program, sequencer) +if (program.saveSequence) saveSequence(program, sequencer); -else if (program.installModule) installModule(program, sequencer) +else if (program.installModule) installModule(program, sequencer); else { // Parse step into an array to allow for multiple steps. - if (!program.step) exit("No steps passed"); - program.step = program.step.split(" "); + if (!program.step) exit('No steps passed'); + program.step = program.step.split(' '); // User must input an image. - if (!program.image) exit("Can't read file."); + if (!program.image) exit('Can\'t read file.'); // User must input an image. fs.access(program.image, function(err) { - if (err) exit("Can't read file."); + if (err) exit('Can\'t read file.'); }); // User must input a step. If steps exist, check that every step is a valid step. if (!program.step || !(utils.validateSteps(program.step, sequencer))) - exit("Please ensure all steps are valid."); + exit('Please ensure all steps are valid.'); // If there's no user defined output directory, select a default directory. - program.output = program.output || "./output/"; + program.output = program.output || './output/'; // Set sequencer to log module outputs, if any. sequencer.setUI({ @@ -57,7 +57,7 @@ else { step.info = sequencer.modulesInfo(step.name); for (var output in step.info.outputs) { - console.log("[" + program.step + "]: " + output + " = " + step[output]); + console.log('[' + program.step + ']: ' + output + ' = ' + step[output]); } }, notify: function(msg) { @@ -68,8 +68,8 @@ else { // Finally, if everything is alright, load the image, add the steps and run the sequencer. sequencer.loadImages(program.image, function() { console.warn( - "\x1b[33m%s\x1b[0m", - "Please wait \n output directory generated will be empty until the execution is complete" + '\x1b[33m%s\x1b[0m', + 'Please wait \n output directory generated will be empty until the execution is complete' ); //Generate the Output Directory @@ -82,7 +82,7 @@ else { outputFilename = null; } - sequencerSteps(program, sequencer, outputFilename) + sequencerSteps(program, sequencer, outputFilename); }); diff --git a/package.json b/package.json index 07347bdf..1d866019 100644 --- a/package.json +++ b/package.json @@ -10,6 +10,12 @@ "setup": "npm i && npm i -g grunt grunt-cli && grunt build", "start": "grunt serve" }, + "lint-staged": { + "*.js": [ + "./node_modules/.bin/eslint --fix", + "git add" + ] + }, "repository": { "type": "git", "url": "git+https://github.com/publiclab/image-sequencer.git" @@ -30,6 +36,7 @@ "commander": "^2.11.0", "data-uri-to-buffer": "^2.0.0", "downloadjs": "^1.4.7", + "eslint": "^5.16.0", "fisheyegl": "^0.1.2", "font-awesome": "~4.7.0", "geotiff": "^1.0.0-beta.6", @@ -62,17 +69,20 @@ "@babel/plugin-syntax-object-rest-spread": "^7.2.0", "babelify": "^10.0.0", "browserify": "16.2.3", + "eslint": "^5.16.0", "grunt": "^1.0.3", "grunt-browser-sync": "^2.2.0", "grunt-browserify": "^5.0.0", "grunt-contrib-concat": "^1.0.1", "grunt-contrib-uglify-es": "^3.3.0", "grunt-contrib-watch": "^1.1.0", + "husky": "^2.2.0", "image-filter-core": "~2.0.2", "image-filter-threshold": "~2.0.1", "jasmine-core": "^3.3.0", "jasmine-jquery": "^2.1.1", "jasmine-spec-reporter": "^4.2.1", + "lint-staged": "^8.1.6", "looks-same": "^7.0.0", "matchdep": "^2.0.0", "tap-spec": "^5.0.0", @@ -80,6 +90,11 @@ "tape-run": "^6.0.0", "uglify-es": "^3.3.7" }, + "husky": { + "hooks": { + "pre-commit": "lint-staged" + } + }, "homepage": "https://sequencer.publiclab.org", "bin": { "sequencer": "./index.js" diff --git a/spec/defaultHtmlSequencerUi.spec.js b/spec/defaultHtmlSequencerUi.spec.js index ea53c682..acbe757d 100644 --- a/spec/defaultHtmlSequencerUi.spec.js +++ b/spec/defaultHtmlSequencerUi.spec.js @@ -1,42 +1,42 @@ describe('Default sequencer HTML', function() { - var DefaultHtmlSequencerUi = require('../examples/lib/defaultHtmlSequencerUi') - var sequencer = require('../src/ImageSequencer')() + var DefaultHtmlSequencerUi = require('../examples/lib/defaultHtmlSequencerUi'); + var sequencer = require('../src/ImageSequencer')(); var defaultHtmlSequencerUi; beforeEach(()=>{ - defaultHtmlSequencerUi = new DefaultHtmlSequencerUi(sequencer) + defaultHtmlSequencerUi = new DefaultHtmlSequencerUi(sequencer); - spyOn(defaultHtmlSequencerUi,'onLoad') - spyOn(defaultHtmlSequencerUi,'selectNewStepUi') - spyOn(defaultHtmlSequencerUi,'removeStepUi') - spyOn(defaultHtmlSequencerUi,'addStepUi') - spyOn(defaultHtmlSequencerUi,'importStepsFromUrlHash') + spyOn(defaultHtmlSequencerUi,'onLoad'); + spyOn(defaultHtmlSequencerUi,'selectNewStepUi'); + spyOn(defaultHtmlSequencerUi,'removeStepUi'); + spyOn(defaultHtmlSequencerUi,'addStepUi'); + spyOn(defaultHtmlSequencerUi,'importStepsFromUrlHash'); - defaultHtmlSequencerUi.onLoad() - defaultHtmlSequencerUi.selectNewStepUi() - defaultHtmlSequencerUi.addStepUi() - defaultHtmlSequencerUi.removeStepUi() - defaultHtmlSequencerUi.importStepsFromUrlHash() - }) + defaultHtmlSequencerUi.onLoad(); + defaultHtmlSequencerUi.selectNewStepUi(); + defaultHtmlSequencerUi.addStepUi(); + defaultHtmlSequencerUi.removeStepUi(); + defaultHtmlSequencerUi.importStepsFromUrlHash(); + }); it('load default ui', function() { - expect(defaultHtmlSequencerUi.onLoad).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.onLoad).toHaveBeenCalled(); + }); it('select step ui', function() { - expect(defaultHtmlSequencerUi.selectNewStepUi).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.selectNewStepUi).toHaveBeenCalled(); + }); it('add step ui', function() { - expect(defaultHtmlSequencerUi.addStepUi).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.addStepUi).toHaveBeenCalled(); + }); it('remove step ui', function() { - expect(defaultHtmlSequencerUi.removeStepUi).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.removeStepUi).toHaveBeenCalled(); + }); it('import options from url', function() { - expect(defaultHtmlSequencerUi.importStepsFromUrlHash).toHaveBeenCalled() - }) -}) \ No newline at end of file + expect(defaultHtmlSequencerUi.importStepsFromUrlHash).toHaveBeenCalled(); + }); +}); \ No newline at end of file diff --git a/spec/defaultHtmlStepUi.spec.js b/spec/defaultHtmlStepUi.spec.js index 33eec53d..8af0a62d 100644 --- a/spec/defaultHtmlStepUi.spec.js +++ b/spec/defaultHtmlStepUi.spec.js @@ -1,61 +1,61 @@ var { JSDOM } = require('jsdom'); -var DOM = new JSDOM(``); +var DOM = new JSDOM(''); global.document = DOM.window.document; describe('Sequencer step HTML', function() { - var DefaultHtmlStepUi = require('../examples/lib/defaultHtmlStepUi') - var sequencer = require('../src/ImageSequencer')() + var DefaultHtmlStepUi = require('../examples/lib/defaultHtmlStepUi'); + var sequencer = require('../src/ImageSequencer')(); var defaultHtmlStepUi; - var step = 'brightness' + var step = 'brightness'; var options = { - name: "Brightness", - description: "Change the brightness of the image by given percent value" - } + name: 'Brightness', + description: 'Change the brightness of the image by given percent value' + }; // options = JSON.parse(options) beforeEach(()=>{ - defaultHtmlStepUi = new DefaultHtmlStepUi(sequencer) + defaultHtmlStepUi = new DefaultHtmlStepUi(sequencer); - spyOn(defaultHtmlStepUi,'getPreview') - spyOn(defaultHtmlStepUi,'onSetup') - spyOn(defaultHtmlStepUi,'onComplete') - spyOn(defaultHtmlStepUi,'onDraw') - spyOn(defaultHtmlStepUi,'onRemove') - spyOn(defaultHtmlStepUi,'notify') + spyOn(defaultHtmlStepUi,'getPreview'); + spyOn(defaultHtmlStepUi,'onSetup'); + spyOn(defaultHtmlStepUi,'onComplete'); + spyOn(defaultHtmlStepUi,'onDraw'); + spyOn(defaultHtmlStepUi,'onRemove'); + spyOn(defaultHtmlStepUi,'notify'); - defaultHtmlStepUi.getPreview() - defaultHtmlStepUi.onSetup(step,options) - defaultHtmlStepUi.onComplete(step) - defaultHtmlStepUi.onDraw(step) - defaultHtmlStepUi.onRemove(step) - defaultHtmlStepUi.notify('Step removed','remove-notification') - }) + defaultHtmlStepUi.getPreview(); + defaultHtmlStepUi.onSetup(step,options); + defaultHtmlStepUi.onComplete(step); + defaultHtmlStepUi.onDraw(step); + defaultHtmlStepUi.onRemove(step); + defaultHtmlStepUi.notify('Step removed','remove-notification'); + }); it('result preview ui', function() { - expect(defaultHtmlStepUi.getPreview).toHaveBeenCalled() - }) + expect(defaultHtmlStepUi.getPreview).toHaveBeenCalled(); + }); it('load initial setup ui', function() { - expect(defaultHtmlStepUi.onSetup).toHaveBeenCalledWith(step,options) - }) + expect(defaultHtmlStepUi.onSetup).toHaveBeenCalledWith(step,options); + }); it('load completion ui', function() { - expect(defaultHtmlStepUi.onComplete).toHaveBeenCalledWith(step) - }) + expect(defaultHtmlStepUi.onComplete).toHaveBeenCalledWith(step); + }); it('draw step ui', function() { - expect(defaultHtmlStepUi.onDraw).toHaveBeenCalledWith(step) - }) + expect(defaultHtmlStepUi.onDraw).toHaveBeenCalledWith(step); + }); it('remove step ui', function() { - expect(defaultHtmlStepUi.onRemove).toHaveBeenCalledWith(step) - }) + expect(defaultHtmlStepUi.onRemove).toHaveBeenCalledWith(step); + }); it('notification ui', function() { - expect(defaultHtmlStepUi.notify).toHaveBeenCalledWith('Step removed','remove-notification') - }) + expect(defaultHtmlStepUi.notify).toHaveBeenCalledWith('Step removed','remove-notification'); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/spec/insertPreview.spec.js b/spec/insertPreview.spec.js index 0073557c..fb5736c5 100644 --- a/spec/insertPreview.spec.js +++ b/spec/insertPreview.spec.js @@ -1,26 +1,26 @@ describe('Preview UI HTML', function() { - var InsertPreview = require('../examples/lib/insertPreview') - var sequencer = require('../src/ImageSequencer')() + var InsertPreview = require('../examples/lib/insertPreview'); + var sequencer = require('../src/ImageSequencer')(); var insertPreview; - var options = { brightness: 50 } + var options = { brightness: 50 }; beforeEach(()=>{ - insertPreview = InsertPreview + insertPreview = InsertPreview; - spyOn(insertPreview,'generatePreview') - spyOn(insertPreview,'updatePreviews') + spyOn(insertPreview,'generatePreview'); + spyOn(insertPreview,'updatePreviews'); - insertPreview.generatePreview('brightness',options,'src','selector') - insertPreview.updatePreviews('src','selector') - }) + insertPreview.generatePreview('brightness',options,'src','selector'); + insertPreview.updatePreviews('src','selector'); + }); it('generate preview ui', function() { - expect(insertPreview.generatePreview).toHaveBeenCalledWith('brightness',options,'src','selector') - }) + expect(insertPreview.generatePreview).toHaveBeenCalledWith('brightness',options,'src','selector'); + }); it('update preview ui', function() { - expect(insertPreview.updatePreviews).toHaveBeenCalledWith('src','selector') - }) + expect(insertPreview.updatePreviews).toHaveBeenCalledWith('src','selector'); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/spec/intermediateHtmlStepUi.spec.js b/spec/intermediateHtmlStepUi.spec.js index 9cd012d6..a919788f 100644 --- a/spec/intermediateHtmlStepUi.spec.js +++ b/spec/intermediateHtmlStepUi.spec.js @@ -1,19 +1,19 @@ describe('Intermediate step HTML', function() { - var IntermediateHtmlStepUi = require('../examples/lib/intermediateHtmlStepUi') - var sequencer = require('../src/ImageSequencer')() + var IntermediateHtmlStepUi = require('../examples/lib/intermediateHtmlStepUi'); + var sequencer = require('../src/ImageSequencer')(); var intermediateHtmlStepUi; beforeEach(()=>{ - intermediateHtmlStepUi = new IntermediateHtmlStepUi(sequencer) + intermediateHtmlStepUi = new IntermediateHtmlStepUi(sequencer); - spyOn(intermediateHtmlStepUi,'insertStep') + spyOn(intermediateHtmlStepUi,'insertStep'); - intermediateHtmlStepUi.insertStep() - }) + intermediateHtmlStepUi.insertStep(); + }); it('insert step ui', function() { - expect(intermediateHtmlStepUi.insertStep).toHaveBeenCalled() - }) + expect(intermediateHtmlStepUi.insertStep).toHaveBeenCalled(); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/spec/urlHash.spec.js b/spec/urlHash.spec.js index 99f6a047..e7a08f61 100644 --- a/spec/urlHash.spec.js +++ b/spec/urlHash.spec.js @@ -1,40 +1,40 @@ describe('URL manipulation methods', function() { - var UrlHash = require('../examples/lib/urlHash') + var UrlHash = require('../examples/lib/urlHash'); var urlHash; var params = { module: 'brightness', brightness: 50 - } + }; beforeEach(()=>{ - urlHash = UrlHash + urlHash = UrlHash; - spyOn(urlHash,'getUrlHashParameters') - spyOn(urlHash,'getUrlHashParameter') - spyOn(urlHash,'setUrlHashParameters') - spyOn(urlHash,'setUrlHashParameter') + spyOn(urlHash,'getUrlHashParameters'); + spyOn(urlHash,'getUrlHashParameter'); + spyOn(urlHash,'setUrlHashParameters'); + spyOn(urlHash,'setUrlHashParameter'); - urlHash.getUrlHashParameters() - urlHash.getUrlHashParameter('module') - urlHash.setUrlHashParameters(params) - urlHash.setUrlHashParameter('module','brightness') - }) + urlHash.getUrlHashParameters(); + urlHash.getUrlHashParameter('module'); + urlHash.setUrlHashParameters(params); + urlHash.setUrlHashParameter('module','brightness'); + }); it('gets url hash params from window hash', function() { - expect(urlHash.getUrlHashParameters).toHaveBeenCalled() - }) + expect(urlHash.getUrlHashParameters).toHaveBeenCalled(); + }); it('gets url hash param from params object', function() { - expect(urlHash.getUrlHashParameter).toHaveBeenCalledWith('module') - }) + expect(urlHash.getUrlHashParameter).toHaveBeenCalledWith('module'); + }); it('accepts param object and sets url hash params', function() { - expect(urlHash.setUrlHashParameters).toHaveBeenCalledWith(params) - }) + expect(urlHash.setUrlHashParameters).toHaveBeenCalledWith(params); + }); it('accepts param key-value pair and sets url hash params', function() { - expect(urlHash.setUrlHashParameter).toHaveBeenCalledWith('module','brightness') - }) + expect(urlHash.setUrlHashParameter).toHaveBeenCalledWith('module','brightness'); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/src/CliUtils.js b/src/CliUtils.js index d415769f..5a55cf09 100644 --- a/src/CliUtils.js +++ b/src/CliUtils.js @@ -1,18 +1,18 @@ -var fs = require('fs') +var fs = require('fs'); /* * This function checks if the directory exists, if not it creates one on the given path * Callback is called with argument error if an error is encountered */ function makedir(path,callback){ - fs.access(path,function(err){ - if(err) fs.mkdir(path,function(err){ - if(err) callback(err); - callback(); - }); - else callback() + fs.access(path,function(err){ + if(err) fs.mkdir(path,function(err){ + if(err) callback(err); + callback(); }); -}; + else callback(); + }); +} // Takes an array of steps and checks if they are valid steps for the sequencer. function validateSteps(steps, sequencer) { @@ -37,9 +37,9 @@ function validateConfig(config_, options_) { for (var input in options_) { if (!config_[options_[input]]) { console.error( - "\x1b[31m%s\x1b[0m", + '\x1b[31m%s\x1b[0m', `Options Object does not have the required details "${ - options_[input] + options_[input] }" not specified. Fallback case activated` ); return false; @@ -52,7 +52,7 @@ function validateConfig(config_, options_) { } module.exports = exports = { - makedir: makedir, - validateSteps: validateSteps, - validateConfig: validateConfig -} \ No newline at end of file + makedir: makedir, + validateSteps: validateSteps, + validateConfig: validateConfig +}; \ No newline at end of file diff --git a/src/ExportBin.js b/src/ExportBin.js index 25b9f1be..d2708466 100755 --- a/src/ExportBin.js +++ b/src/ExportBin.js @@ -2,7 +2,7 @@ var fs = require('fs'); var getDirectories = function(rootDir, cb) { fs.readdir(rootDir, function(err, files) { var dirs = []; - if (typeof (files) == "undefined" || files.length == 0) { + if (typeof (files) == 'undefined' || files.length == 0) { cb(dirs); return []; } @@ -21,15 +21,15 @@ var getDirectories = function(rootDir, cb) { } } }); -} +}; -module.exports = function ExportBin(dir = "./output/", ref, basic, filename) { +module.exports = function ExportBin(dir = './output/', ref, basic, filename) { // If user did not give an output filename so we can continue without doing anything - dir = (dir[dir.length - 1] == "/") ? dir : dir + "/"; + dir = (dir[dir.length - 1] == '/') ? dir : dir + '/'; if (ref.options.inBrowser) return false; fs.access(dir, function(err) { - if (err) console.error(err) + if (err) console.error(err); }); if (filename && basic) { var steps = ref.steps; @@ -53,17 +53,17 @@ module.exports = function ExportBin(dir = "./output/", ref, basic, filename) { var datauri = steps.slice(-1)[0].output.src; var ext = steps.slice(-1)[0].output.format; var buffer = require('data-uri-to-buffer')(datauri); - fs.writeFile(root + "image" + "_" + (steps.length - 1) + "." + ext, buffer, function() { }); + fs.writeFile(root + 'image' + '_' + (steps.length - 1) + '.' + ext, buffer, function() { }); } else { for (var i in steps) { var datauri = steps[i].output.src; var ext = steps[i].output.format; var buffer = require('data-uri-to-buffer')(datauri); - fs.writeFile(root + "image" + "_" + i + "." + ext, buffer, function() { }); + fs.writeFile(root + 'image' + '_' + i + '.' + ext, buffer, function() { }); } } }); }); } -} +}; diff --git a/src/FormatInput.js b/src/FormatInput.js index 0bcd63e6..5cbe09d6 100644 --- a/src/FormatInput.js +++ b/src/FormatInput.js @@ -1,5 +1,5 @@ function objTypeOf(object){ - return Object.prototype.toString.call(object).split(" ")[1].slice(0,-1) + return Object.prototype.toString.call(object).split(' ')[1].slice(0,-1); } function getPrimitive(object){ @@ -7,13 +7,13 @@ function getPrimitive(object){ } function makeArray(input) { - return (objTypeOf(input)=="Array")?input:[input]; + return (objTypeOf(input)=='Array')?input:[input]; } function copy(a) { - if (!typeof(a) == "object") return a; - if (objTypeOf(a) == "Array") return a.slice(); - if (objTypeOf(a) == "Object") { + if (!typeof(a) == 'object') return a; + if (objTypeOf(a) == 'Array') return a.slice(); + if (objTypeOf(a) == 'Object') { var b = {}; for (var v in a) { b[v] = copy(a[v]); @@ -26,77 +26,77 @@ function copy(a) { function formatInput(args,format,images) { var json_q = {}; var format_i = format; - if (format == "+") + if (format == '+') format = ['string_a', 'o_object']; - else if (format == "-") + else if (format == '-') format = ['number_a']; - else if (format == "^") + else if (format == '^') format = ['number', 'string', 'o_object']; - else if (format == "r") + else if (format == 'r') format = ['o_number']; - else if (format == "l") + else if (format == 'l') format = ['string','o_function']; - if(format[format.length-1] == "o_object") { - if(objTypeOf(args[args.length-1]) != "Object") + if(format[format.length-1] == 'o_object') { + if(objTypeOf(args[args.length-1]) != 'Object') args.push({}); } - else if (format[format.length-1] == "o_number") { - if(typeof(args[args.length-1]) != "number" && objTypeOf(args[0])!="Object") + else if (format[format.length-1] == 'o_number') { + if(typeof(args[args.length-1]) != 'number' && objTypeOf(args[0])!='Object') args.push(1); } - else if (format[format.length-1] == "o_function") { - if(objTypeOf(args[args.length-1]) != "Function" && objTypeOf(args[0])!="Object") + else if (format[format.length-1] == 'o_function') { + if(objTypeOf(args[args.length-1]) != 'Function' && objTypeOf(args[0])!='Object') args.push(function(){}); } if(args.length == format.length) {//making of arrays for (var i in format) { - if (format[i].substr(format[i].length-2,2)=="_a") + if (format[i].substr(format[i].length-2,2)=='_a') args[i] = makeArray(args[i]); } } if (args.length == 1 ) { - if(format_i == "r") json_q = {0:copy(args[0])}; - else if(format_i == "-") { + if(format_i == 'r') json_q = {0:copy(args[0])}; + else if(format_i == '-') { json_q=[]; json_q= copy(args[0]); } } - else if (format_i == "r" ) { + else if (format_i == 'r' ) { for (var img in args[0]) json_q = {0:args[0]}; } - else if (format_i == "l") { + else if (format_i == 'l') { json_q = { image: args[0], callback: args[1] - } + }; } else { - json_q = []; - if(format_i == "+") { - for(var s in args[0]) { - json_q.push({ - name: args[0][s], - o: args[1] - }); - } - } - - - if(format_i == "^") { - var size = this.steps.length; - var index = args[0]; - index = (index==size)?index:index%size; - if (index<0) index += size+1; + json_q = []; + if(format_i == '+') { + for(var s in args[0]) { json_q.push({ - index: index, - name: args[1], - o: args[2] + name: args[0][s], + o: args[1] }); + } + } + + + if(format_i == '^') { + var size = this.steps.length; + var index = args[0]; + index = (index==size)?index:index%size; + if (index<0) index += size+1; + json_q.push({ + index: index, + name: args[1], + o: args[2] + }); } } diff --git a/src/ImageSequencer.js b/src/ImageSequencer.js index f9f7bd02..f3e4afaf 100644 --- a/src/ImageSequencer.js +++ b/src/ImageSequencer.js @@ -1,29 +1,29 @@ -if (typeof window !== 'undefined') { isBrowser = true } -else { var isBrowser = false } +if (typeof window !== 'undefined') { isBrowser = true; } +else { var isBrowser = false; } require('./util/getStep.js'); ImageSequencer = function ImageSequencer(options) { - var sequencer = (this.name == "ImageSequencer") ? this : this.sequencer; + var sequencer = (this.name == 'ImageSequencer') ? this : this.sequencer; options = options || {}; options.inBrowser = options.inBrowser === undefined ? isBrowser : options.inBrowser; options.sequencerCounter = 0; function objTypeOf(object) { - return Object.prototype.toString.call(object).split(" ")[1].slice(0, -1) + return Object.prototype.toString.call(object).split(' ')[1].slice(0, -1); } function log(color, msg) { - if (options.ui != "none") { + if (options.ui != 'none') { if (arguments.length == 1) console.log(arguments[0]); else if (arguments.length == 2) console.log(color, msg); } } function copy(a) { - if (!typeof (a) == "object") return a; - if (objTypeOf(a) == "Array") return a.slice(); - if (objTypeOf(a) == "Object") { + if (!typeof (a) == 'object') return a; + if (objTypeOf(a) == 'Array') return a.slice(); + if (objTypeOf(a) == 'Object') { var b = {}; for (var v in a) { b[v] = copy(a[v]); @@ -34,7 +34,7 @@ ImageSequencer = function ImageSequencer(options) { } function makeArray(input) { - return (objTypeOf(input) == "Array") ? input : [input]; + return (objTypeOf(input) == 'Array') ? input : [input]; } var image, @@ -64,15 +64,15 @@ ImageSequencer = function ImageSequencer(options) { // else if (options.imageUrl) loadImage(imageUrl); function addSteps() { - var this_ = (this.name == "ImageSequencer") ? this : this.sequencer; + var this_ = (this.name == 'ImageSequencer') ? this : this.sequencer; var args = []; var json_q = {}; for (var arg in arguments) { args.push(copy(arguments[arg])); } - json_q = formatInput.call(this_, args, "+"); + json_q = formatInput.call(this_, args, '+'); - inputlog.push({ method: "addSteps", json_q: copy(json_q) }); - for (var j in json_q) - require("./AddStep")(this_, json_q[j].name, json_q[j].o); + inputlog.push({ method: 'addSteps', json_q: copy(json_q) }); + for (var j in json_q) + require('./AddStep')(this_, json_q[j].name, json_q[j].o); return this; } @@ -89,31 +89,31 @@ ImageSequencer = function ImageSequencer(options) { function removeSteps() { var indices; - var this_ = (this.name == "ImageSequencer") ? this : this.sequencer; + var this_ = (this.name == 'ImageSequencer') ? this : this.sequencer; var args = []; for (var arg in arguments) args.push(copy(arguments[arg])); - var json_q = formatInput.call(this_, args, "-"); - inputlog.push({ method: "removeSteps", json_q: copy(json_q) }); + var json_q = formatInput.call(this_, args, '-'); + inputlog.push({ method: 'removeSteps', json_q: copy(json_q) }); - indices = json_q.sort(function(a, b) { return b - a }); - for (var i in indices) - removeStep(this_, indices[i]); + indices = json_q.sort(function(a, b) { return b - a; }); + for (var i in indices) + removeStep(this_, indices[i]); return this; } function insertSteps() { - var this_ = (this.name == "ImageSequencer") ? this : this.sequencer; - var args = [] + var this_ = (this.name == 'ImageSequencer') ? this : this.sequencer; + var args = []; for (var arg in arguments) args.push(arguments[arg]); - var json_q = formatInput.call(this_, args, "^"); - inputlog.push({ method: "insertSteps", json_q: copy(json_q) }); + var json_q = formatInput.call(this_, args, '^'); + inputlog.push({ method: 'insertSteps', json_q: copy(json_q) }); - var details = json_q; - details = details.sort(function(a, b) { return b.index - a.index }); - for (var i in details) - require("./InsertStep")(this_, details[i].index, details[i].name, details[i].o); + var details = json_q; + details = details.sort(function(a, b) { return b.index - a.index; }); + for (var i in details) + require('./InsertStep')(this_, details[i].index, details[i].name, details[i].o); return this; } @@ -124,21 +124,21 @@ ImageSequencer = function ImageSequencer(options) { config = config || { mode: 'no-arg' }; if (config.index) index = config.index; - if (config.mode != "no-arg" && typeof config != 'function') { - if (config.progressObj) progressObj = config.progressObj; - delete arguments['0']; - } + if (config.mode != 'no-arg' && typeof config != 'function') { + if (config.progressObj) progressObj = config.progressObj; + delete arguments['0']; + } - var this_ = (this.name == "ImageSequencer") ? this : this.sequencer; + var this_ = (this.name == 'ImageSequencer') ? this : this.sequencer; var args = []; for (var arg in arguments) args.push(copy(arguments[arg])); var callback = function() { }; for (var arg in args) - if (objTypeOf(args[arg]) == "Function") + if (objTypeOf(args[arg]) == 'Function') callback = args.splice(arg, 1)[0]; //callback is formed - var json_q = formatInput.call(this_, args, "r"); + var json_q = formatInput.call(this_, args, 'r'); require('./Run')(this_, json_q, callback, index, progressObj); @@ -147,19 +147,19 @@ ImageSequencer = function ImageSequencer(options) { function loadImages() { var args = []; - var prevSteps = this.getSteps().slice(1).map(step=>step.options.name) + var prevSteps = this.getSteps().slice(1).map(step=>step.options.name); var sequencer = this; sequencer.image = arguments[0]; for (var arg in arguments) args.push(copy(arguments[arg])); - var json_q = formatInput.call(this, args, "l"); + var json_q = formatInput.call(this, args, 'l'); if(this.getSteps().length!=0){ this.options.sequencerCounter = 0; inputlog = []; this.steps = []; } - inputlog.push({ method: "loadImages", json_q: copy(json_q) }); + inputlog.push({ method: 'loadImages', json_q: copy(json_q) }); var ret = { - name: "ImageSequencer Wrapper", + name: 'ImageSequencer Wrapper', sequencer: this, addSteps: this.addSteps, removeSteps: this.removeSteps, @@ -170,11 +170,11 @@ ImageSequencer = function ImageSequencer(options) { }; function loadPrevSteps(ref){ if(prevSteps.length!=0){ - ref.addSteps(prevSteps) + ref.addSteps(prevSteps); prevSteps=[]; } } - require('./ui/LoadImage')(sequencer, "image", json_q.image, function() { + require('./ui/LoadImage')(sequencer, 'image', json_q.image, function() { loadPrevSteps(sequencer); json_q.callback.call(ret); }); @@ -198,11 +198,11 @@ ImageSequencer = function ImageSequencer(options) { var exportBin = function(dir, basic, filename) { return require('./ExportBin')(dir, this, basic, filename); - } + }; function modulesInfo(name) { - var modulesdata = {} - if (name == "load-image") return {}; + var modulesdata = {}; + if (name == 'load-image') return {}; if (arguments.length == 0) { for (var modulename in this.modules) { modulesdata[modulename] = modules[modulename][1]; @@ -213,8 +213,8 @@ ImageSequencer = function ImageSequencer(options) { } else { if (modules[name]){ - modulesdata = modules[name][1]; - } + modulesdata = modules[name][1]; + } else modulesdata = { 'inputs': sequences[name]['options'] }; } @@ -253,7 +253,7 @@ ImageSequencer = function ImageSequencer(options) { return; } var mods = fs.readFileSync('./src/Modules.js').toString(); - mods = mods.substr(0, mods.length - 1) + " '" + name + "': require('" + path + "'),\n}"; + mods = mods.substr(0, mods.length - 1) + ' \'' + name + '\': require(\'' + path + '\'),\n}'; fs.writeFileSync('./src/Modules.js', mods); } @@ -283,11 +283,11 @@ ImageSequencer = function ImageSequencer(options) { this.sequences = require('./SavedSequences.json'); } - var str = require('./Strings.js')(this.steps, modulesInfo, addSteps, copy) + var str = require('./Strings.js')(this.steps, modulesInfo, addSteps, copy); return { //literals and objects - name: "ImageSequencer", + name: 'ImageSequencer', options: options, inputlog: inputlog, modules: modules, @@ -331,7 +331,7 @@ ImageSequencer = function ImageSequencer(options) { copy: copy, setInputStep: require('./ui/SetInputStep')(sequencer) - } + }; -} +}; module.exports = ImageSequencer; diff --git a/src/InsertStep.js b/src/InsertStep.js index e49d54e9..de87f483 100644 --- a/src/InsertStep.js +++ b/src/InsertStep.js @@ -7,7 +7,7 @@ function InsertStep(ref, index, name, o) { } if (ref.detectStringSyntax(name)) { - return ref.stringToSteps(name) + return ref.stringToSteps(name); } function insertStep(index, name, o_) { @@ -43,7 +43,7 @@ function InsertStep(ref, index, name, o) { let step = stepsArray[i]; ref.insertSteps(index + Number.parseInt(i), step['name'], step['options']); } - } + }; // Tell UI that a step has been set up. o = o || {}; diff --git a/src/Modules.js b/src/Modules.js index 75c5888e..ef56d4f5 100644 --- a/src/Modules.js +++ b/src/Modules.js @@ -42,4 +42,4 @@ module.exports = { 'tint': require('./modules/Tint'), 'webgl-distort': require('./modules/WebglDistort'), 'white-balance': require('./modules/WhiteBalance') -} +}; diff --git a/src/ReplaceImage.js b/src/ReplaceImage.js index b0604650..17e2b064 100644 --- a/src/ReplaceImage.js +++ b/src/ReplaceImage.js @@ -33,19 +33,19 @@ function ReplaceImage(ref,selector,steps,options) { } var base64 = btoa(raw); - var dataURL="data:image/"+ext+";base64," + base64; + var dataURL='data:image/'+ext+';base64,' + base64; make(dataURL); }; - if(url.substr(0,11).toLowerCase()!="data:image/") xmlHTTP.send(); + if(url.substr(0,11).toLowerCase()!='data:image/') xmlHTTP.send(); else make(url); function make(url) { tempSequencer.loadImage(url, function(){ // this.addSteps(steps).run({stop:function(){}},function(out){ - var sequence = this.addSteps(steps) + var sequence = this.addSteps(steps); if (ref.detectStringSyntax(steps)) - sequence = this.stringToSteps(steps) + sequence = this.stringToSteps(steps); sequence.run({stop:function(){}},function(out){ img.src = out; }); diff --git a/src/Run.js b/src/Run.js index 54c5b2c3..fd47711a 100644 --- a/src/Run.js +++ b/src/Run.js @@ -5,7 +5,7 @@ function Run(ref, json_q, callback, ind, progressObj) { function drawStep(drawarray, pos) { if (pos == drawarray.length && drawarray[pos - 1] !== undefined) { - if (ref.objTypeOf(callback) == "Function" && ref.steps.slice(-1)[0].output) { + if (ref.objTypeOf(callback) == 'Function' && ref.steps.slice(-1)[0].output) { var steps = ref.steps; var out = steps[steps.length - 1].output.src; callback(out); @@ -25,7 +25,7 @@ function Run(ref, json_q, callback, ind, progressObj) { }; step.getIndex = function getIndex() { return i; - } + }; for (var util in getStepUtils) { if (getStepUtils.hasOwnProperty(util)) { @@ -58,26 +58,26 @@ function Run(ref, json_q, callback, ind, progressObj) { function drawSteps(json_q) { var drawarray = [], - no_steps = ref.steps.length, - init = json_q[0]; - for (var i = 0; i < no_steps - init; i++) { - drawarray.push({i: init + i }); - } + no_steps = ref.steps.length, + init = json_q[0]; + for (var i = 0; i < no_steps - init; i++) { + drawarray.push({i: init + i }); + } drawStep(drawarray, ind); } function filter(json_q) { - if (json_q[0] == 0 && ref.steps.length == 1) - delete json_q[0]; - else if (json_q[0] == 0) json_q[0]++; - var prevstep = ref.steps[json_q[0] - 1]; - while ( - typeof prevstep == "undefined" || - typeof prevstep.output == "undefined" - ) { - prevstep = ref.steps[--json_q[0] - 1]; - } + if (json_q[0] == 0 && ref.steps.length == 1) + delete json_q[0]; + else if (json_q[0] == 0) json_q[0]++; + var prevstep = ref.steps[json_q[0] - 1]; + while ( + typeof prevstep == 'undefined' || + typeof prevstep.output == 'undefined' + ) { + prevstep = ref.steps[--json_q[0] - 1]; + } return json_q; } diff --git a/src/RunToolkit.js b/src/RunToolkit.js index 8b4db5fa..a6eca171 100644 --- a/src/RunToolkit.js +++ b/src/RunToolkit.js @@ -5,10 +5,10 @@ const dataUriToBuffer = require('data-uri-to-buffer'); const savePixels = require('save-pixels'); module.exports = function(input) { - input.getPixels = getPixels; - input.pixelManipulation = pixelManipulation; - input.lodash = lodash; - input.dataUriToBuffer = dataUriToBuffer; - input.savePixels = savePixels; - return input; -} \ No newline at end of file + input.getPixels = getPixels; + input.pixelManipulation = pixelManipulation; + input.lodash = lodash; + input.dataUriToBuffer = dataUriToBuffer; + input.savePixels = savePixels; + return input; +}; \ No newline at end of file diff --git a/src/Strings.js b/src/Strings.js index 3ae913ff..91514eb5 100644 --- a/src/Strings.js +++ b/src/Strings.js @@ -1,44 +1,44 @@ module.exports = function(steps, modulesInfo, addSteps, copy) { // Genates a CLI string for the current sequence function toCliString() { - var cliStringSteps = `"`, cliOptions = {}; + var cliStringSteps = '"', cliOptions = {}; for (var step in this.steps) { - var name = (typeof this.steps[step].options !== "undefined")? this.steps[step].options.name : this.steps[step].name - if (name !== "load-image"){ + var name = (typeof this.steps[step].options !== 'undefined')? this.steps[step].options.name : this.steps[step].name; + if (name !== 'load-image'){ cliStringSteps += `${name} `; } for (var inp in modulesInfo(name).inputs) { cliOptions[inp] = this.steps[step].options[inp]; } } - cliStringSteps = cliStringSteps.substr(0, cliStringSteps.length - 1) + `"`; - return `sequencer -i [PATH] -s ${cliStringSteps} -d '${JSON.stringify(cliOptions)}'` + cliStringSteps = cliStringSteps.substr(0, cliStringSteps.length - 1) + '"'; + return `sequencer -i [PATH] -s ${cliStringSteps} -d '${JSON.stringify(cliOptions)}'`; } // Checks if input is a string of comma separated module names function detectStringSyntax(str) { - let result = (str.includes(',') || str.includes('{')) ? true : false - return result + let result = (str.includes(',') || str.includes('{')) ? true : false; + return result; } // Parses input string and returns array of module names function parseStringSyntax(str) { - let stringifiedNames = str.replace(/\s/g, '') - let moduleNames = stringifiedNames.split(',') - return moduleNames + let stringifiedNames = str.replace(/\s/g, ''); + let moduleNames = stringifiedNames.split(','); + return moduleNames; } // imports string of comma separated module names to sequencer steps function stringToSteps(str) { let sequencer = this; - let names = [] - if (this.name != "ImageSequencer") + let names = []; + if (this.name != 'ImageSequencer') sequencer = this.sequencer; if (detectStringSyntax(str)) - names = stringToJSON(str) + names = stringToJSON(str); names.forEach(function eachStep(stepObj) { - sequencer.addSteps(stepObj.name, stepObj.options) - }) + sequencer.addSteps(stepObj.name, stepObj.options); + }); } // Strigifies the current sequence @@ -96,7 +96,7 @@ module.exports = function(steps, modulesInfo, addSteps, copy) { if (str.indexOf(bracesStrings[0]) === -1) { // if there are no settings specified var moduleName = str.substr(0); - stepSettings = ""; + stepSettings = ''; } else { var moduleName = str.substr(0, str.indexOf(bracesStrings[0])); stepSettings = str.slice(str.indexOf(bracesStrings[0]) + 1, -1); @@ -112,20 +112,20 @@ module.exports = function(steps, modulesInfo, addSteps, copy) { settingName, settingValue ]; - if (!!settingName) accumulator[settingName] = settingValue; + if (settingName) accumulator[settingName] = settingValue; return accumulator; }, {}); return { name: moduleName, options: stepSettings - } + }; } // imports a string into the sequencer steps function importString(str) { let sequencer = this; - if (this.name != "ImageSequencer") + if (this.name != 'ImageSequencer') sequencer = this.sequencer; var stepsFromString = stringToJSON(str); stepsFromString.forEach(function eachStep(stepObj) { @@ -136,7 +136,7 @@ module.exports = function(steps, modulesInfo, addSteps, copy) { // imports a array of JSON steps into the sequencer steps function importJSON(obj) { let sequencer = this; - if (this.name != "ImageSequencer") + if (this.name != 'ImageSequencer') sequencer = this.sequencer; obj.forEach(function eachStep(stepObj) { sequencer.addSteps(stepObj.name, stepObj.options); @@ -155,5 +155,5 @@ module.exports = function(steps, modulesInfo, addSteps, copy) { stringToJSONstep: stringToJSONstep, importString: importString, importJSON: importJSON - } -} \ No newline at end of file + }; +}; \ No newline at end of file diff --git a/src/cli/installModule.js b/src/cli/installModule.js index 913f12df..5a27b233 100644 --- a/src/cli/installModule.js +++ b/src/cli/installModule.js @@ -1,17 +1,17 @@ -var childProcess = require('child_process') +var childProcess = require('child_process'); var Spinner = require('ora'); module.exports = function (program, sequencer) { - console.log( - "\x1b[33m%s\x1b[0m", - "Please wait while your Module is being Installed...\nThis may take a while!" - ); + console.log( + '\x1b[33m%s\x1b[0m', + 'Please wait while your Module is being Installed...\nThis may take a while!' + ); - var params = program.installModule.split(' '); - var spinner = Spinner("Now Installing...").start(); - childProcess.execSync(`npm i ${params[1]}`) - sequencer.saveNewModule(params[0], params[1]); - sequencer.loadNewModule(params[0], require(params[1])); - spinner.stop(); - console.log("\x1b[32m%s\x1b[0m", "Your module was installed successfully!!"); -} \ No newline at end of file + var params = program.installModule.split(' '); + var spinner = Spinner('Now Installing...').start(); + childProcess.execSync(`npm i ${params[1]}`); + sequencer.saveNewModule(params[0], params[1]); + sequencer.loadNewModule(params[0], require(params[1])); + spinner.stop(); + console.log('\x1b[32m%s\x1b[0m', 'Your module was installed successfully!!'); +}; \ No newline at end of file diff --git a/src/cli/saveSequence.js b/src/cli/saveSequence.js index 91ad7ec4..759c75d1 100644 --- a/src/cli/saveSequence.js +++ b/src/cli/saveSequence.js @@ -1,7 +1,7 @@ module.exports = function (program, sequencer) { - var params = program.saveSequence.split(' '); - sequencer.saveSequence(params[0], params[1]); - console.log("\x1b[32m", "Your sequence was saved successfully!!"); + var params = program.saveSequence.split(' '); + sequencer.saveSequence(params[0], params[1]); + console.log('\x1b[32m', 'Your sequence was saved successfully!!'); -} \ No newline at end of file +}; \ No newline at end of file diff --git a/src/cli/sequencerSteps.js b/src/cli/sequencerSteps.js index c6f69ddf..3603bb32 100644 --- a/src/cli/sequencerSteps.js +++ b/src/cli/sequencerSteps.js @@ -1,13 +1,13 @@ var Spinner = require('ora'); var readlineSync = require('readline-sync'); -var utils = require('../CliUtils') +var utils = require('../CliUtils'); module.exports = function (program, sequencer, outputFilename) { utils.makedir(program.output, () => { console.log('Files will be exported to "' + program.output + '"'); if (program.basic) - console.log("Basic mode is enabled, outputting only final image"); + console.log('Basic mode is enabled, outputting only final image'); // Iterate through the steps and retrieve their inputs. program.step.forEach(function(step) { @@ -15,7 +15,7 @@ module.exports = function (program, sequencer, outputFilename) { // If inputs exists, print to console. if (Object.keys(options).length) { - console.log("[" + step + "]: Inputs"); + console.log('[' + step + ']: Inputs'); } // If inputs exists, print them out with descriptions. @@ -23,9 +23,9 @@ module.exports = function (program, sequencer, outputFilename) { // The array below creates a variable number of spaces. This is done with (length + 1). // The extra 4 that makes it (length + 5) is to account for the []: characters console.log( - new Array(step.length + 5).join(" ") + + new Array(step.length + 5).join(' ') + input + - ": " + + ': ' + options[input].desc ); }); @@ -33,18 +33,18 @@ module.exports = function (program, sequencer, outputFilename) { if (program.config) { try { var config = JSON.parse(program.config); - console.log(`The parsed options object: `, config); + console.log('The parsed options object: ', config); } catch (e) { console.error( - "\x1b[31m%s\x1b[0m", - `Options(Config) is not a not valid JSON Fallback activate` + '\x1b[31m%s\x1b[0m', + 'Options(Config) is not a not valid JSON Fallback activate' ); program.config = false; console.log(e); } } if (program.config && utils.validateConfig(config, options)) { - console.log("Now using Options object"); + console.log('Now using Options object'); Object.keys(options).forEach(function(input) { options[input] = config[input]; }); @@ -52,15 +52,15 @@ module.exports = function (program, sequencer, outputFilename) { // If inputs exist, iterate through them and prompt for values. Object.keys(options).forEach(function(input) { var value = readlineSync.question( - "[" + + '[' + step + - "]: Enter a value for " + + ']: Enter a value for ' + input + - " (" + + ' (' + options[input].type + - ", default: " + + ', default: ' + options[input].default + - "): " + '): ' ); options[input] = value; }); @@ -71,7 +71,7 @@ module.exports = function (program, sequencer, outputFilename) { var spinnerObj = { succeed: () => { }, stop: () => { } }; if (!process.env.TEST) - spinnerObj = Spinner("Your Image is being processed..").start(); + spinnerObj = Spinner('Your Image is being processed..').start(); // Run the sequencer. sequencer.run({ progressObj: spinnerObj }, function() { @@ -81,8 +81,8 @@ module.exports = function (program, sequencer, outputFilename) { //check if spinner was not overriden stop it if (!spinnerObj.overrideFlag) { spinnerObj.succeed(); - console.log(`\nDone!!`); + console.log('\nDone!!'); } }); }); -} \ No newline at end of file +}; \ No newline at end of file diff --git a/src/modules/AddQR/Module.js b/src/modules/AddQR/Module.js index 04e1fd3b..53a9fbbe 100644 --- a/src/modules/AddQR/Module.js +++ b/src/modules/AddQR/Module.js @@ -1,51 +1,51 @@ module.exports = function AddQR(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.size = options.size || defaults.size; - options.qrCodeString = options.qrCodeString || "https://github.com/publiclab/image-sequencer"; - var output; - getPixels = require('get-pixels'); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.size = options.size || defaults.size; + options.qrCodeString = options.qrCodeString || 'https://github.com/publiclab/image-sequencer'; + var output; + getPixels = require('get-pixels'); - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - return getPixels(input.src, function (err, oldPixels) { - function changePixel(r, g, b, a) { - return [r, g, b, a]; - } + return getPixels(input.src, function (err, oldPixels) { + function changePixel(r, g, b, a) { + return [r, g, b, a]; + } - function extraManipulation(pixels,generateOutput) { - if (err) { - console.log(err); - return; - } - require('./QR')(options, pixels, oldPixels, generateOutput); - } - function output(image, datauri, mimetype) { - step.output = { src: datauri, format: mimetype }; - } + function extraManipulation(pixels,generateOutput) { + if (err) { + console.log(err); + return; + } + require('./QR')(options, pixels, oldPixels, generateOutput); + } + function output(image, datauri, mimetype) { + step.output = { src: datauri, format: mimetype }; + } - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); - }) - - } - - return { - options: options, - draw: draw, + return require('../_nomodule/PixelManipulation.js')(input, { output: output, - UI: UI - } -} \ No newline at end of file + changePixel: changePixel, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + }); + + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; \ No newline at end of file diff --git a/src/modules/AddQR/QR.js b/src/modules/AddQR/QR.js index d2424cd8..487ccbd7 100644 --- a/src/modules/AddQR/QR.js +++ b/src/modules/AddQR/QR.js @@ -1,48 +1,48 @@ module.exports = exports = function (options, pixels, oldPixels, callback) { - var QRCode = require('qrcode') - QRCode.toDataURL(options.qrCodeString, function (err, url) { - var getPixels = require("get-pixels"); - getPixels(url, function (err, qrPixels) { - if (err) { - console.log("Bad image path", image); - } + var QRCode = require('qrcode'); + QRCode.toDataURL(options.qrCodeString, function (err, url) { + var getPixels = require('get-pixels'); + getPixels(url, function (err, qrPixels) { + if (err) { + console.log('Bad image path', image); + } - var imagejs = require('imagejs'); - var bitmap = new imagejs.Bitmap({ width: qrPixels.shape[0], height: qrPixels.shape[1] }); - bitmap._data.data = qrPixels.data; - var resized = bitmap.resize({ - width: options.size, height: options.size, - algorithm: "bicubicInterpolation" - }); + var imagejs = require('imagejs'); + var bitmap = new imagejs.Bitmap({ width: qrPixels.shape[0], height: qrPixels.shape[1] }); + bitmap._data.data = qrPixels.data; + var resized = bitmap.resize({ + width: options.size, height: options.size, + algorithm: 'bicubicInterpolation' + }); - qrPixels.data = resized._data.data; - qrPixels.shape = [options.size, options.size, 4]; - qrPixels.stride[1] = 4 * options.size; + qrPixels.data = resized._data.data; + qrPixels.shape = [options.size, options.size, 4]; + qrPixels.stride[1] = 4 * options.size; - var width = oldPixels.shape[0], - height = oldPixels.shape[1]; - var xe = width - options.size, - ye = height - options.size; - for (var m = 0; m < width; m++) { - for (var n = 0; n < height; n++) { - if (m >= xe && n >= ye) { - pixels.set(m, n, 0, qrPixels.get(m - xe, n - ye, 0)) - pixels.set(m, n, 1, qrPixels.get(m - xe, n - ye, 1)) - pixels.set(m, n, 2, qrPixels.get(m - xe, n - ye, 2)) - pixels.set(m, n, 3, qrPixels.get(m - xe, n - ye, 3)) - } + var width = oldPixels.shape[0], + height = oldPixels.shape[1]; + var xe = width - options.size, + ye = height - options.size; + for (var m = 0; m < width; m++) { + for (var n = 0; n < height; n++) { + if (m >= xe && n >= ye) { + pixels.set(m, n, 0, qrPixels.get(m - xe, n - ye, 0)); + pixels.set(m, n, 1, qrPixels.get(m - xe, n - ye, 1)); + pixels.set(m, n, 2, qrPixels.get(m - xe, n - ye, 2)); + pixels.set(m, n, 3, qrPixels.get(m - xe, n - ye, 3)); + } - else { - pixels.set(m, n, 0, oldPixels.get(m, n, 0)) - pixels.set(m, n, 1, oldPixels.get(m, n, 1)) - pixels.set(m, n, 2, oldPixels.get(m, n, 2)) - pixels.set(m, n, 3, oldPixels.get(m, n, 3)) - } + else { + pixels.set(m, n, 0, oldPixels.get(m, n, 0)); + pixels.set(m, n, 1, oldPixels.get(m, n, 1)); + pixels.set(m, n, 2, oldPixels.get(m, n, 2)); + pixels.set(m, n, 3, oldPixels.get(m, n, 3)); + } - } - } - callback(); + } + } + callback(); - }) - }) -} + }); + }); +}; diff --git a/src/modules/AddQR/index.js b/src/modules/AddQR/index.js index 11ef888f..71549002 100644 --- a/src/modules/AddQR/index.js +++ b/src/modules/AddQR/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Average/Module.js b/src/modules/Average/Module.js index e19f24d0..e7992863 100755 --- a/src/modules/Average/Module.js +++ b/src/modules/Average/Module.js @@ -3,72 +3,72 @@ */ module.exports = function Average(options, UI) { - var output; + var output; - options.step.metadata = options.step.metadata || {}; + options.step.metadata = options.step.metadata || {}; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - // do the averaging - function extraManipulation(pixels) { - var i = 0, sum = [0, 0, 0, 0]; - while (i < pixels.data.length) { - sum[0] += pixels.data[i++]; - sum[1] += pixels.data[i++]; - sum[2] += pixels.data[i++]; - sum[3] += pixels.data[i++]; - } + // do the averaging + function extraManipulation(pixels) { + var i = 0, sum = [0, 0, 0, 0]; + while (i < pixels.data.length) { + sum[0] += pixels.data[i++]; + sum[1] += pixels.data[i++]; + sum[2] += pixels.data[i++]; + sum[3] += pixels.data[i++]; + } - let divisor = pixels.data.length / 4; + let divisor = pixels.data.length / 4; - sum[0] = Math.floor(sum[0] / divisor); - sum[1] = Math.floor(sum[1] / divisor); - sum[2] = Math.floor(sum[2] / divisor); - sum[3] = Math.floor(sum[3] / divisor); + sum[0] = Math.floor(sum[0] / divisor); + sum[1] = Math.floor(sum[1] / divisor); + sum[2] = Math.floor(sum[2] / divisor); + sum[3] = Math.floor(sum[3] / divisor); - i = 0 - while (i < pixels.data.length) { - pixels.data[i++] = sum[0]; - pixels.data[i++] = sum[1]; - pixels.data[i++] = sum[2]; - pixels.data[i++] = sum[3]; - } + i = 0; + while (i < pixels.data.length) { + pixels.data[i++] = sum[0]; + pixels.data[i++] = sum[1]; + pixels.data[i++] = sum[2]; + pixels.data[i++] = sum[3]; + } - // report back and store average in metadata: - options.step.metadata.averages = sum; - - // TODO: refactor into a new "display()" method as per https://github.com/publiclab/image-sequencer/issues/242 - if (options.step.inBrowser && options.step.ui) $(options.step.ui).find('.details').append("

Averages (r, g, b, a): " + sum.join(', ') + "

"); - return pixels; - } - - function output(image, datauri, mimetype) { - - // This output is accessible by Image Sequencer - step.output = { - src: datauri, - format: mimetype - }; - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - callback: callback - }); + // report back and store average in metadata: + options.step.metadata.averages = sum; + // TODO: refactor into a new "display()" method as per https://github.com/publiclab/image-sequencer/issues/242 + if (options.step.inBrowser && options.step.ui) $(options.step.ui).find('.details').append('

Averages (r, g, b, a): ' + sum.join(', ') + '

'); + return pixels; } - return { - options: options, - draw: draw, - output: output, - UI: UI + + function output(image, datauri, mimetype) { + + // This output is accessible by Image Sequencer + step.output = { + src: datauri, + format: mimetype + }; } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Average/index.js b/src/modules/Average/index.js index 11ef888f..71549002 100644 --- a/src/modules/Average/index.js +++ b/src/modules/Average/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Blend/Module.js b/src/modules/Blend/Module.js index 62cf12ca..08360196 100644 --- a/src/modules/Blend/Module.js +++ b/src/modules/Blend/Module.js @@ -1,75 +1,75 @@ module.exports = function Dynamic(options, UI, util) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.func = options.func || defaults.blend; - options.offset = options.offset || defaults.offset; + options.func = options.func || defaults.blend; + options.offset = options.offset || defaults.offset; - var output; + var output; - // This function is called on every draw. - function draw(input, callback, progressObj) { + // This function is called on every draw. + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - // convert to runnable code: - if (typeof options.func === "string") eval('options.func = ' + options.func); + // convert to runnable code: + if (typeof options.func === 'string') eval('options.func = ' + options.func); - var getPixels = require('get-pixels'); + var getPixels = require('get-pixels'); - // convert offset as string to int - if (typeof options.offset === "string") options.offset = parseInt(options.offset); + // convert offset as string to int + if (typeof options.offset === 'string') options.offset = parseInt(options.offset); - // save first image's pixels - var priorStep = this.getStep(options.offset); + // save first image's pixels + var priorStep = this.getStep(options.offset); - if (priorStep.output === undefined) { - this.output = input; - UI.notify('Offset Unavailable', 'offset-notification'); - callback(); - } + if (priorStep.output === undefined) { + this.output = input; + UI.notify('Offset Unavailable', 'offset-notification'); + callback(); + } - getPixels(priorStep.output.src, function(err, pixels) { - options.firstImagePixels = pixels; + getPixels(priorStep.output.src, function(err, pixels) { + options.firstImagePixels = pixels; - function changePixel(r2, g2, b2, a2, x, y) { - // blend! - let p = options.firstImagePixels; - return options.func( - r2, g2, b2, a2, - p.get(x, y, 0), - p.get(x, y, 1), - p.get(x, y, 2), - p.get(x, y, 3) - ) - } + function changePixel(r2, g2, b2, a2, x, y) { + // blend! + let p = options.firstImagePixels; + return options.func( + r2, g2, b2, a2, + p.get(x, y, 0), + p.get(x, y, 1), + p.get(x, y, 2), + p.get(x, y, 3) + ); + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; - } + } - // run PixelManipulatin on second image's pixels - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); - }); - } - - return { - options: options, - draw: draw, + // run PixelManipulatin on second image's pixels + return require('../_nomodule/PixelManipulation.js')(input, { output: output, - UI: UI - } -} + changePixel: changePixel, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Blend/index.js b/src/modules/Blend/index.js index 11ef888f..71549002 100644 --- a/src/modules/Blend/index.js +++ b/src/modules/Blend/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Blur/Blur.js b/src/modules/Blur/Blur.js index ba15a91d..43b1d7dd 100755 --- a/src/modules/Blur/Blur.js +++ b/src/modules/Blur/Blur.js @@ -4,29 +4,29 @@ module.exports = exports = function(pixels, blur) { r: [], g: [], b: [], - } + }; for (let y = 0; y < pixels.shape[1]; y++){ - pixs.r.push([]) - pixs.g.push([]) - pixs.b.push([]) + pixs.r.push([]); + pixs.g.push([]); + pixs.b.push([]); for (let x = 0; x < pixels.shape[0]; x++){ - pixs.r[y].push(pixels.get(x, y, 0)) - pixs.g[y].push(pixels.get(x, y, 1)) - pixs.b[y].push(pixels.get(x, y, 2)) + pixs.r[y].push(pixels.get(x, y, 0)); + pixs.g[y].push(pixels.get(x, y, 1)); + pixs.b[y].push(pixels.get(x, y, 2)); } } - const convolve = require('../_nomodule/gpuUtils').convolve + const convolve = require('../_nomodule/gpuUtils').convolve; - const conPix = convolve([pixs.r, pixs.g, pixs.b], kernel) + const conPix = convolve([pixs.r, pixs.g, pixs.b], kernel); for (let y = 0; y < pixels.shape[1]; y++){ for (let x = 0; x < pixels.shape[0]; x++){ - pixels.set(x, y, 0, Math.max(0, Math.min(conPix[0][y][x], 255))) - pixels.set(x, y, 1, Math.max(0, Math.min(conPix[1][y][x], 255))) - pixels.set(x, y, 2, Math.max(0, Math.min(conPix[2][y][x], 255))) + pixels.set(x, y, 0, Math.max(0, Math.min(conPix[0][y][x], 255))); + pixels.set(x, y, 1, Math.max(0, Math.min(conPix[1][y][x], 255))); + pixels.set(x, y, 2, Math.max(0, Math.min(conPix[2][y][x], 255))); } } @@ -38,25 +38,25 @@ module.exports = exports = function(pixels, blur) { let kernel = [], sum = 0; - if (sigma == 0) sigma += 0.05 + if (sigma == 0) sigma += 0.05; const s = 2 * Math.pow(sigma, 2); for (let y = -2; y <= 2; y++) { - kernel.push([]) + kernel.push([]); for (let x = -2; x <= 2; x++) { - let r = Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)) - kernel[y + 2].push(Math.exp(-(r / s))) - sum += kernel[y + 2][x + 2] + let r = Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)); + kernel[y + 2].push(Math.exp(-(r / s))); + sum += kernel[y + 2][x + 2]; } } for (let x = 0; x < 5; x++){ for (let y = 0; y < 5; y++){ - kernel[y][x] = (kernel[y][x] / sum) + kernel[y][x] = (kernel[y][x] / sum); } } return kernel; } -} +}; diff --git a/src/modules/Blur/Module.js b/src/modules/Blur/Module.js index 4844e501..4d4eda63 100755 --- a/src/modules/Blur/Module.js +++ b/src/modules/Blur/Module.js @@ -3,43 +3,43 @@ */ module.exports = function Blur(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.blur = options.blur || defaults.blur; - options.blur = parseFloat(options.blur); - var output; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.blur = options.blur || defaults.blur; + options.blur = parseFloat(options.blur); + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { - pixels = require('./Blur')(pixels, options.blur); - return pixels; - } + function extraManipulation(pixels) { + pixels = require('./Blur')(pixels, options.blur); + return pixels; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Blur/index.js b/src/modules/Blur/index.js index 11ef888f..71549002 100644 --- a/src/modules/Blur/index.js +++ b/src/modules/Blur/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Brightness/Module.js b/src/modules/Brightness/Module.js index 53e63c1b..71fbf830 100644 --- a/src/modules/Brightness/Module.js +++ b/src/modules/Brightness/Module.js @@ -3,55 +3,55 @@ */ module.exports = function Brightness(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - var output; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - options.brightness = options.brightness || defaults.brightness; + options.brightness = options.brightness || defaults.brightness; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - /* + /* In this case progress is handled by changepixel internally otherwise progressObj needs to be overriden and used For eg. progressObj = new SomeProgressModule() */ - var step = this, val = (options.brightness) / 100.0;; + var step = this, val = (options.brightness) / 100.0; - function changePixel(r, g, b, a) { + function changePixel(r, g, b, a) { - r = Math.min(val * r, 255); - g = Math.min(val * g, 255); - b = Math.min(val * b, 255); - return [r, g, b, a]; - } + r = Math.min(val * r, 255); + g = Math.min(val * g, 255); + b = Math.min(val * b, 255); + return [r, g, b, a]; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Brightness/index.js b/src/modules/Brightness/index.js index 11ef888f..71549002 100644 --- a/src/modules/Brightness/index.js +++ b/src/modules/Brightness/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/CanvasResize/Module.js b/src/modules/CanvasResize/Module.js index 00a2dde8..5251a955 100644 --- a/src/modules/CanvasResize/Module.js +++ b/src/modules/CanvasResize/Module.js @@ -3,61 +3,61 @@ */ module.exports = function canvasResize(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - var output; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - options.width = options.width || defaults.width; - options.height = options.height || defaults.height; - options.x = options.x || defaults.x; - options.y = options.y || defaults.y; + options.width = options.width || defaults.width; + options.height = options.height || defaults.height; + options.x = options.x || defaults.x; + options.y = options.y || defaults.y; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { + function extraManipulation(pixels) { - let newPixels = require('ndarray')(new Uint8Array(4 * options.width * options.height).fill(255), [options.width, options.height, 4]); - let iMax = options.width - options.x, - jMax = options.height - options.y; - for (let i = 0; i < iMax && i < pixels.shape[0]; i++) { - for (let j = 0; j < jMax && j < pixels.shape[1]; j++) { - let x = i + options.x, y = j + options.y; - newPixels.set(x, y, 0, pixels.get(i, j, 0)); - newPixels.set(x, y, 1, pixels.get(i, j, 1)); - newPixels.set(x, y, 2, pixels.get(i, j, 2)); - newPixels.set(x, y, 3, pixels.get(i, j, 3)); - } - } - return newPixels; + let newPixels = require('ndarray')(new Uint8Array(4 * options.width * options.height).fill(255), [options.width, options.height, 4]); + let iMax = options.width - options.x, + jMax = options.height - options.y; + for (let i = 0; i < iMax && i < pixels.shape[0]; i++) { + for (let j = 0; j < jMax && j < pixels.shape[1]; j++) { + let x = i + options.x, y = j + options.y; + newPixels.set(x, y, 0, pixels.get(i, j, 0)); + newPixels.set(x, y, 1, pixels.get(i, j, 1)); + newPixels.set(x, y, 2, pixels.get(i, j, 2)); + newPixels.set(x, y, 3, pixels.get(i, j, 3)); } + } + return newPixels; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/CanvasResize/index.js b/src/modules/CanvasResize/index.js index 11ef888f..71549002 100644 --- a/src/modules/CanvasResize/index.js +++ b/src/modules/CanvasResize/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Channel/Module.js b/src/modules/Channel/Module.js index 7c8181f4..4d12ab02 100644 --- a/src/modules/Channel/Module.js +++ b/src/modules/Channel/Module.js @@ -17,9 +17,9 @@ module.exports = function Channel(options, UI) { var step = this; function changePixel(r, g, b, a) { - if (options.channel === "red") return [r, 0, 0, a]; - if (options.channel === "green") return [0, g, 0, a]; - if (options.channel === "blue") return [0, 0, b, a]; + if (options.channel === 'red') return [r, 0, 0, a]; + if (options.channel === 'green') return [0, g, 0, a]; + if (options.channel === 'blue') return [0, 0, b, a]; } function output(image, datauri, mimetype) { @@ -46,5 +46,5 @@ module.exports = function Channel(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/Channel/index.js b/src/modules/Channel/index.js index 11ef888f..71549002 100644 --- a/src/modules/Channel/index.js +++ b/src/modules/Channel/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/ColorTemperature/Module.js b/src/modules/ColorTemperature/Module.js index 89b2de09..c035fbfa 100644 --- a/src/modules/ColorTemperature/Module.js +++ b/src/modules/ColorTemperature/Module.js @@ -1,81 +1,81 @@ module.exports = function ColorTemperature(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - options.temperature = (options.temperature > "40000") ? "40000" : options.temperature + options.temperature = (options.temperature > '40000') ? '40000' : options.temperature; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { + function extraManipulation(pixels) { - let temp = parseInt(options.temperature) - temp /= 100 + let temp = parseInt(options.temperature); + temp /= 100; - let r, g, b; + let r, g, b; - if (temp <= 66) { - r = 255; - g = Math.min(Math.max(99.4708025861 * Math.log(temp) - 161.1195681661, 0), 255); - } else { - r = Math.min(Math.max(329.698727446 * Math.pow(temp - 60, -0.1332047592), 0), 255); - g = Math.min(Math.max(288.1221695283 * Math.pow(temp - 60, -0.0755148492), 0), 255); - } + if (temp <= 66) { + r = 255; + g = Math.min(Math.max(99.4708025861 * Math.log(temp) - 161.1195681661, 0), 255); + } else { + r = Math.min(Math.max(329.698727446 * Math.pow(temp - 60, -0.1332047592), 0), 255); + g = Math.min(Math.max(288.1221695283 * Math.pow(temp - 60, -0.0755148492), 0), 255); + } - if (temp >= 66) { - b = 255; - } else if (temp <= 19) { - b = 0; - } else { - b = temp - 10; - b = Math.min(Math.max(138.5177312231 * Math.log(b) - 305.0447927307, 0), 255); - } + if (temp >= 66) { + b = 255; + } else if (temp <= 19) { + b = 0; + } else { + b = temp - 10; + b = Math.min(Math.max(138.5177312231 * Math.log(b) - 305.0447927307, 0), 255); + } - for (let i = 0; i < pixels.shape[0]; i++) { - for (let j = 0; j < pixels.shape[1]; j++) { + for (let i = 0; i < pixels.shape[0]; i++) { + for (let j = 0; j < pixels.shape[1]; j++) { - r_data = pixels.get(i, j, 0) - r_new_data = (255 / r) * r_data - pixels.set(i, j, 0, r_new_data) + r_data = pixels.get(i, j, 0); + r_new_data = (255 / r) * r_data; + pixels.set(i, j, 0, r_new_data); - g_data = pixels.get(i, j, 1) - g_new_data = (255 / g) * g_data - pixels.set(i, j, 1, g_new_data) + g_data = pixels.get(i, j, 1); + g_new_data = (255 / g) * g_data; + pixels.set(i, j, 1, g_new_data); - b_data = pixels.get(i, j, 2) - b_new_data = (255 / b) * b_data - pixels.set(i, j, 2, b_new_data) - } - } - - return pixels + b_data = pixels.get(i, j, 2); + b_new_data = (255 / b) * b_data; + pixels.set(i, j, 2, b_new_data); } + } - function output(image, datauri, mimetype) { - - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + return pixels; } - return { - options: options, - draw: draw, - output: output, - UI: UI + function output(image, datauri, mimetype) { + + step.output = { src: datauri, format: mimetype }; + } -} \ No newline at end of file + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; + +}; \ No newline at end of file diff --git a/src/modules/ColorTemperature/index.js b/src/modules/ColorTemperature/index.js index 49feec2b..981be0a5 100644 --- a/src/modules/ColorTemperature/index.js +++ b/src/modules/ColorTemperature/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] + require('./Module'), + require('./info.json') +]; diff --git a/src/modules/Colorbar/index.js b/src/modules/Colorbar/index.js index 11ef888f..71549002 100644 --- a/src/modules/Colorbar/index.js +++ b/src/modules/Colorbar/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Colormap/Colormap.js b/src/modules/Colormap/Colormap.js index 737a11be..e7848e91 100644 --- a/src/modules/Colormap/Colormap.js +++ b/src/modules/Colormap/Colormap.js @@ -14,14 +14,14 @@ module.exports = function Colormap(value, options) { options.colormap = options.colormap || colormaps.default; // if a lookup table is provided as an array: - if(typeof(options.colormap) == "object") + if(typeof(options.colormap) == 'object') colormapFunction = colormap(options.colormap); // if a stored colormap is named with a string like "fastie": else if(colormaps.hasOwnProperty(options.colormap)) colormapFunction = colormaps[options.colormap]; else colormapFunction = colormaps.default; return colormapFunction(value / 255.00); -} +}; function colormap(segments) { return function(x) { @@ -49,149 +49,149 @@ function colormap(segments) { } return result; }; -}; +} var colormaps = { greyscale: colormap([ - [0, [0, 0, 0], [255, 255, 255] ], - [1, [255, 255, 255], [255, 255, 255] ] - ]), + [0, [0, 0, 0], [255, 255, 255] ], + [1, [255, 255, 255], [255, 255, 255] ] + ]), - bluwhtgrngis: colormap([ - [0, [6,23,86], [6,25, 84] ], - [0.0625, [6,25,84], [6,25, 84] ],//1 - [0.125, [6,25,84], [6,25, 84] ],//2 - [0.1875, [6,25,84], [6,25, 84] ], - [0.25, [6,25,84], [6,25,84] ], - [0.3125, [6,25,84], [9,24, 84] ],//5 - [0.3438, [9,24, 84], [119,120,162] ],//5 - [0.375, [119,129,162],[249,250,251] ], //6 - [0.406, [249,250,251],[255,255,255] ], //6.5 - [0.4375, [255,255,255],[255,255,255] ], //7 white - [0.50, [255,255,255],[214,205,191] ],//8 - [0.52, [214,205,191],[178,175,96] ],//8.2 - [0.5625, [178,175,96], [151,176,53] ],//9 - [0.593, [151,176,53], [146,188,12] ],//9.5 - [0.625, [146,188,12], [96,161,1] ], //10 - [0.6875, [96,161,1], [30,127,3] ],//11 - [0.75, [30,127,3], [0,99,1] ],//12 - [0.8125, [0,99,1], [0,74,1] ],//13 - [0.875, [0,74,1], [0,52, 0] ],//14 - [0.9375, [0,52, 0], [0,34,0] ], //15 - [0.968, [0,34,0], [68,70,67] ] //16 - ]), + bluwhtgrngis: colormap([ + [0, [6,23,86], [6,25, 84] ], + [0.0625, [6,25,84], [6,25, 84] ],//1 + [0.125, [6,25,84], [6,25, 84] ],//2 + [0.1875, [6,25,84], [6,25, 84] ], + [0.25, [6,25,84], [6,25,84] ], + [0.3125, [6,25,84], [9,24, 84] ],//5 + [0.3438, [9,24, 84], [119,120,162] ],//5 + [0.375, [119,129,162],[249,250,251] ], //6 + [0.406, [249,250,251],[255,255,255] ], //6.5 + [0.4375, [255,255,255],[255,255,255] ], //7 white + [0.50, [255,255,255],[214,205,191] ],//8 + [0.52, [214,205,191],[178,175,96] ],//8.2 + [0.5625, [178,175,96], [151,176,53] ],//9 + [0.593, [151,176,53], [146,188,12] ],//9.5 + [0.625, [146,188,12], [96,161,1] ], //10 + [0.6875, [96,161,1], [30,127,3] ],//11 + [0.75, [30,127,3], [0,99,1] ],//12 + [0.8125, [0,99,1], [0,74,1] ],//13 + [0.875, [0,74,1], [0,52, 0] ],//14 + [0.9375, [0,52, 0], [0,34,0] ], //15 + [0.968, [0,34,0], [68,70,67] ] //16 + ]), brntogrn: colormap([ - [0, [110,12,3], [118,6,1] ], - [0.0625, [118,6,1], [141,19,6] ], - [0.125, [141,19,6], [165,35,13] ], - [0.1875, [165,35,13], [177,59,25] ], - [0.2188, [177,59,25], [192,91,36] ], - [0.25, [192,91,36], [214, 145, 76] ], - [0.3125, [214,145,76], [230,183,134] ], - [0.375, [230,183,134],[243, 224, 194]], - [0.4375, [243,224,194],[250,252,229] ], - [0.50, [250,252,229],[217,235,185] ], - [0.5625, [217,235,185],[184,218,143] ], - [0.625, [184,218,143],[141,202,89] ], - [0.6875, [141,202,89], [80,176,61] ], - [0.75, [80,176,61], [0, 147, 32] ], - [0.8125, [0,147,32], [1, 122, 22] ], - [0.875, [1,122,22], [0, 114, 19] ], - [0.90, [0,114,19], [0,105,18] ], - [0.9375, [0,105,18], [7,70,14] ] + [0, [110,12,3], [118,6,1] ], + [0.0625, [118,6,1], [141,19,6] ], + [0.125, [141,19,6], [165,35,13] ], + [0.1875, [165,35,13], [177,59,25] ], + [0.2188, [177,59,25], [192,91,36] ], + [0.25, [192,91,36], [214, 145, 76] ], + [0.3125, [214,145,76], [230,183,134] ], + [0.375, [230,183,134],[243, 224, 194]], + [0.4375, [243,224,194],[250,252,229] ], + [0.50, [250,252,229],[217,235,185] ], + [0.5625, [217,235,185],[184,218,143] ], + [0.625, [184,218,143],[141,202,89] ], + [0.6875, [141,202,89], [80,176,61] ], + [0.75, [80,176,61], [0, 147, 32] ], + [0.8125, [0,147,32], [1, 122, 22] ], + [0.875, [1,122,22], [0, 114, 19] ], + [0.90, [0,114,19], [0,105,18] ], + [0.9375, [0,105,18], [7,70,14] ] - ]), + ]), blutoredjet: colormap([ - [0, [0,0,140], [1,1,186] ], - [0.0625, [1,1,186], [0,1,248] ], - [0.125, [0,1,248], [0,70,254] ], - [0.1875, [0,70,254], [0,130,255] ], - [0.25, [0,130,255], [2,160,255] ], + [0, [0,0,140], [1,1,186] ], + [0.0625, [1,1,186], [0,1,248] ], + [0.125, [0,1,248], [0,70,254] ], + [0.1875, [0,70,254], [0,130,255] ], + [0.25, [0,130,255], [2,160,255] ], [0.2813, [2,160,255], [0,187,255] ], //inset - [0.3125, [0,187,255], [6,250,255] ], - // [0.348, [0,218,255], [8,252,251] ],//inset - [0.375, [8,252,251], [27,254,228] ], - [0.406, [27,254,228], [70,255,187] ], //insert - [0.4375, [70,255,187], [104,254,151]], - [0.47, [104,254,151],[132,255,19] ],//insert - [0.50, [132,255,19], [195,255,60] ], - [0.5625, [195,255,60], [231,254,25] ], - [0.5976, [231,254,25], [253,246,1] ],//insert - [0.625, [253,246,1], [252,210,1] ], //yellow - [0.657, [252,210,1], [255,183,0] ],//insert - [0.6875, [255,183,0], [255,125,2] ], - [0.75, [255,125,2], [255,65, 1] ], - [0.8125, [255,65, 1], [247, 1, 1] ], - [0.875, [247,1,1], [200, 1, 3] ], - [0.9375, [200,1,3], [122, 3, 2] ] + [0.3125, [0,187,255], [6,250,255] ], + // [0.348, [0,218,255], [8,252,251] ],//inset + [0.375, [8,252,251], [27,254,228] ], + [0.406, [27,254,228], [70,255,187] ], //insert + [0.4375, [70,255,187], [104,254,151]], + [0.47, [104,254,151],[132,255,19] ],//insert + [0.50, [132,255,19], [195,255,60] ], + [0.5625, [195,255,60], [231,254,25] ], + [0.5976, [231,254,25], [253,246,1] ],//insert + [0.625, [253,246,1], [252,210,1] ], //yellow + [0.657, [252,210,1], [255,183,0] ],//insert + [0.6875, [255,183,0], [255,125,2] ], + [0.75, [255,125,2], [255,65, 1] ], + [0.8125, [255,65, 1], [247, 1, 1] ], + [0.875, [247,1,1], [200, 1, 3] ], + [0.9375, [200,1,3], [122, 3, 2] ] - ]), + ]), colors16: colormap([ - [0, [0,0,0], [0,0,0] ], - [0.0625, [3,1,172], [3,1,172] ], - [0.125, [3,1,222], [3,1, 222] ], - [0.1875, [0,111,255], [0,111,255] ], - [0.25, [3,172,255], [3,172,255] ], - [0.3125, [1,226,255], [1,226,255] ], - [0.375, [2,255,0], [2,255,0] ], - [0.4375, [198,254,0], [190,254,0] ], - [0.50, [252,255,0], [252,255,0] ], - [0.5625, [255,223,3], [255,223,3] ], - [0.625, [255,143,3], [255,143,3] ], - [0.6875, [255,95,3], [255,95,3] ], - [0.75, [242,0,1], [242,0,1] ], - [0.8125, [245,0,170], [245,0,170] ], - [0.875, [223,180,225], [223,180,225] ], - [0.9375, [255,255,255], [255,255, 255]] + [0, [0,0,0], [0,0,0] ], + [0.0625, [3,1,172], [3,1,172] ], + [0.125, [3,1,222], [3,1, 222] ], + [0.1875, [0,111,255], [0,111,255] ], + [0.25, [3,172,255], [3,172,255] ], + [0.3125, [1,226,255], [1,226,255] ], + [0.375, [2,255,0], [2,255,0] ], + [0.4375, [198,254,0], [190,254,0] ], + [0.50, [252,255,0], [252,255,0] ], + [0.5625, [255,223,3], [255,223,3] ], + [0.625, [255,143,3], [255,143,3] ], + [0.6875, [255,95,3], [255,95,3] ], + [0.75, [242,0,1], [242,0,1] ], + [0.8125, [245,0,170], [245,0,170] ], + [0.875, [223,180,225], [223,180,225] ], + [0.9375, [255,255,255], [255,255, 255]] - ]), + ]), - default: colormap([ - [0, [45,1,121], [25,1,137] ], - [0.125, [25,1,137], [0,6,156] ], - [0.1875, [0,6,156], [7,41,172] ], - [0.25, [7,41,172], [22,84,187] ], - [0.3125, [22,84,187], [25,125,194] ], - [0.375, [25,125,194], [26,177,197] ], - [0.4375, [26,177,197], [23,199,193] ], - [0.47, [23,199,193], [25, 200,170] ], - [0.50, [25, 200,170], [21,209,27] ], - [0.5625, [21,209,27], [108,215,18] ], - [0.625, [108,215,18], [166,218,19] ], - [0.6875, [166,218,19], [206,221,20] ], - [0.75, [206,221,20], [222,213,19 ] ], - [0.7813, [222,213,19], [222, 191, 19]], - [0.8125, [222, 191, 19], [227,133,17] ], - [0.875, [227,133,17], [231,83,16] ], - [0.9375, [231,83,16], [220,61,48] ] + default: colormap([ + [0, [45,1,121], [25,1,137] ], + [0.125, [25,1,137], [0,6,156] ], + [0.1875, [0,6,156], [7,41,172] ], + [0.25, [7,41,172], [22,84,187] ], + [0.3125, [22,84,187], [25,125,194] ], + [0.375, [25,125,194], [26,177,197] ], + [0.4375, [26,177,197], [23,199,193] ], + [0.47, [23,199,193], [25, 200,170] ], + [0.50, [25, 200,170], [21,209,27] ], + [0.5625, [21,209,27], [108,215,18] ], + [0.625, [108,215,18], [166,218,19] ], + [0.6875, [166,218,19], [206,221,20] ], + [0.75, [206,221,20], [222,213,19 ] ], + [0.7813, [222,213,19], [222, 191, 19]], + [0.8125, [222, 191, 19], [227,133,17] ], + [0.875, [227,133,17], [231,83,16] ], + [0.9375, [231,83,16], [220,61,48] ] - ]), + ]), fastie: colormap([ - [0, [255, 255, 255], [0, 0, 0] ], - [0.167, [0, 0, 0], [255, 255, 255] ], - [0.33, [255, 255, 255], [0, 0, 0] ], - [0.5, [0, 0, 0], [140, 140, 255] ], - [0.55, [140, 140, 255], [0, 255, 0] ], - [0.63, [0, 255, 0], [255, 255, 0] ], - [0.75, [255, 255, 0], [255, 0, 0] ], - [0.95, [255, 0, 0], [255, 0, 255] ] - ]), + [0, [255, 255, 255], [0, 0, 0] ], + [0.167, [0, 0, 0], [255, 255, 255] ], + [0.33, [255, 255, 255], [0, 0, 0] ], + [0.5, [0, 0, 0], [140, 140, 255] ], + [0.55, [140, 140, 255], [0, 255, 0] ], + [0.63, [0, 255, 0], [255, 255, 0] ], + [0.75, [255, 255, 0], [255, 0, 0] ], + [0.95, [255, 0, 0], [255, 0, 255] ] + ]), stretched: colormap([ - [0, [0, 0, 255], [0, 0, 255] ], - [0.1, [0, 0, 255], [38, 195, 195] ], - [0.5, [0, 150, 0], [255, 255, 0] ], - [0.7, [255, 255, 0], [255, 50, 50] ], - [0.9, [255, 50, 50], [255, 50, 50] ] - ]) + [0, [0, 0, 255], [0, 0, 255] ], + [0.1, [0, 0, 255], [38, 195, 195] ], + [0.5, [0, 150, 0], [255, 255, 0] ], + [0.7, [255, 255, 0], [255, 50, 50] ], + [0.9, [255, 50, 50], [255, 50, 50] ] + ]) -} \ No newline at end of file +}; \ No newline at end of file diff --git a/src/modules/Colormap/Module.js b/src/modules/Colormap/Module.js index 0baafe6a..68fc4551 100644 --- a/src/modules/Colormap/Module.js +++ b/src/modules/Colormap/Module.js @@ -38,5 +38,5 @@ module.exports = function Colormap(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/Colormap/index.js b/src/modules/Colormap/index.js index 11ef888f..71549002 100644 --- a/src/modules/Colormap/index.js +++ b/src/modules/Colormap/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Contrast/Contrast.js b/src/modules/Contrast/Contrast.js index f1da5876..8902aa00 100644 --- a/src/modules/Contrast/Contrast.js +++ b/src/modules/Contrast/Contrast.js @@ -1,47 +1,47 @@ var _ = require('lodash'); module.exports = exports = function(pixels, contrast) { - let oldpix = _.cloneDeep(pixels); - contrast = Number(contrast) - if (contrast < -100) contrast = -100; - if (contrast > 100) contrast = 100; - contrast = (100.0 + contrast) / 100.0; - contrast *= contrast; + let oldpix = _.cloneDeep(pixels); + contrast = Number(contrast); + if (contrast < -100) contrast = -100; + if (contrast > 100) contrast = 100; + contrast = (100.0 + contrast) / 100.0; + contrast *= contrast; - for (let i = 0; i < pixels.shape[0]; i++) { - for (let j = 0; j < pixels.shape[1]; j++) { - var r = oldpix.get(i, j, 0) / 255.0; - r -= 0.5; - r *= contrast; - r += 0.5; - r *= 255; - if (r < 0) r = 0; - if (r > 255) r = 255; + for (let i = 0; i < pixels.shape[0]; i++) { + for (let j = 0; j < pixels.shape[1]; j++) { + var r = oldpix.get(i, j, 0) / 255.0; + r -= 0.5; + r *= contrast; + r += 0.5; + r *= 255; + if (r < 0) r = 0; + if (r > 255) r = 255; - var g = oldpix.get(i, j, 1) / 255.0; - g -= 0.5; - g *= contrast; - g += 0.5; - g *= 255; - if (g < 0) g = 0; - if (g > 255) g = 255; + var g = oldpix.get(i, j, 1) / 255.0; + g -= 0.5; + g *= contrast; + g += 0.5; + g *= 255; + if (g < 0) g = 0; + if (g > 255) g = 255; - var b = oldpix.get(i, j, 2) / 255.0; - b -= 0.5; - b *= contrast; - b += 0.5; - b *= 255; - if (b < 0) b = 0; - if (b > 255) b = 255; + var b = oldpix.get(i, j, 2) / 255.0; + b -= 0.5; + b *= contrast; + b += 0.5; + b *= 255; + if (b < 0) b = 0; + if (b > 255) b = 255; - pixels.set(i, j, 0, r); - pixels.set(i, j, 1, g); - pixels.set(i, j, 2, b); + pixels.set(i, j, 0, r); + pixels.set(i, j, 1, g); + pixels.set(i, j, 2, b); - } } - return pixels; -} \ No newline at end of file + } + return pixels; +}; \ No newline at end of file diff --git a/src/modules/Contrast/Module.js b/src/modules/Contrast/Module.js index f89acc62..f45b0841 100644 --- a/src/modules/Contrast/Module.js +++ b/src/modules/Contrast/Module.js @@ -4,42 +4,42 @@ module.exports = function Contrast(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.contrast = options.contrast || defaults.contrast; - var output; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.contrast = options.contrast || defaults.contrast; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { - pixels = require('./Contrast')(pixels, options.contrast) - return pixels - } + function extraManipulation(pixels) { + pixels = require('./Contrast')(pixels, options.contrast); + return pixels; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Contrast/index.js b/src/modules/Contrast/index.js index 11ef888f..71549002 100644 --- a/src/modules/Contrast/index.js +++ b/src/modules/Contrast/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Convolution/Convolution.js b/src/modules/Convolution/Convolution.js index 449c3dd1..eae6db85 100644 --- a/src/modules/Convolution/Convolution.js +++ b/src/modules/Convolution/Convolution.js @@ -5,42 +5,42 @@ module.exports = exports = function(pixels, constantFactor, kernelValues, texMod r: [], g: [], b: [], - } + }; for (let y = 0; y < pixels.shape[1]; y++){ - pixs.r.push([]) - pixs.g.push([]) - pixs.b.push([]) + pixs.r.push([]); + pixs.g.push([]); + pixs.b.push([]); for (let x = 0; x < pixels.shape[0]; x++){ - pixs.r[y].push(pixels.get(x, y, 0)) - pixs.g[y].push(pixels.get(x, y, 1)) - pixs.b[y].push(pixels.get(x, y, 2)) + pixs.r[y].push(pixels.get(x, y, 0)); + pixs.g[y].push(pixels.get(x, y, 1)); + pixs.b[y].push(pixels.get(x, y, 2)); } } const convolve = require('../_nomodule/gpuUtils').convolve; - const conPix = convolve([pixs.r, pixs.g, pixs.b], kernel, (pixels.shape[0] * pixels.shape[1]) < 400000 ? true : false) + const conPix = convolve([pixs.r, pixs.g, pixs.b], kernel, (pixels.shape[0] * pixels.shape[1]) < 400000 ? true : false); for (let y = 0; y < pixels.shape[1]; y++){ for (let x = 0; x < pixels.shape[0]; x++){ - pixels.set(x, y, 0, Math.max(0, Math.min(conPix[0][y][x], 255))) - pixels.set(x, y, 1, Math.max(0, Math.min(conPix[1][y][x], 255))) - pixels.set(x, y, 2, Math.max(0, Math.min(conPix[2][y][x], 255))) + pixels.set(x, y, 0, Math.max(0, Math.min(conPix[0][y][x], 255))); + pixels.set(x, y, 1, Math.max(0, Math.min(conPix[1][y][x], 255))); + pixels.set(x, y, 2, Math.max(0, Math.min(conPix[2][y][x], 255))); } } return pixels; -} +}; function kernelGenerator(constantFactor, kernelValues) { - kernelValues = kernelValues.split(" "); + kernelValues = kernelValues.split(' '); for (i = 0; i < 9; i++) { kernelValues[i] = Number(kernelValues[i]) * constantFactor; } let k = 0; let arr = []; for (y = 0; y < 3; y++) { - arr.push([]) + arr.push([]); for (x = 0; x < 3; x++) { arr[y].push(kernelValues[k]); k += 1; diff --git a/src/modules/Convolution/Module.js b/src/modules/Convolution/Module.js index e86153ea..4fa741b2 100644 --- a/src/modules/Convolution/Module.js +++ b/src/modules/Convolution/Module.js @@ -1,43 +1,43 @@ module.exports = function Convolution(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.kernelValues = options.kernelValues || defaults.kernelValues; - options.constantFactor = options.constantFactor || defaults.constantFactor; - options.texMode = options.texMode || defaults.texMode; - var output; + options.kernelValues = options.kernelValues || defaults.kernelValues; + options.constantFactor = options.constantFactor || defaults.constantFactor; + options.texMode = options.texMode || defaults.texMode; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { - pixels = require('./Convolution')(pixels, options.constantFactor, options.kernelValues, options.texMode); - return pixels; - } + function extraManipulation(pixels) { + pixels = require('./Convolution')(pixels, options.constantFactor, options.kernelValues, options.texMode); + return pixels; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - callback: callback - }); + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Convolution/index.js b/src/modules/Convolution/index.js index 11ef888f..71549002 100644 --- a/src/modules/Convolution/index.js +++ b/src/modules/Convolution/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Crop/Crop.js b/src/modules/Crop/Crop.js index 5b016815..dd105386 100644 --- a/src/modules/Crop/Crop.js +++ b/src/modules/Crop/Crop.js @@ -1,7 +1,7 @@ module.exports = function Crop(input,options,callback) { var defaults = require('./../../util/getDefaults.js')(require('./info.json')); var getPixels = require('get-pixels'), - savePixels = require('save-pixels'); + savePixels = require('save-pixels'); options.x = parseInt(options.x) || defaults.x; options.y = parseInt(options.y) || defaults.y; @@ -17,18 +17,18 @@ module.exports = function Crop(input,options,callback) { var iw = pixels.shape[0]; //Width of Original Image var ih = pixels.shape[1]; //Height of Original Image var backgroundArray = []; - backgroundColor = options.backgroundColor.split(" "); + backgroundColor = options.backgroundColor.split(' '); for(var i = 0; i < w ; i++){ backgroundArray = backgroundArray.concat([backgroundColor[0],backgroundColor[1],backgroundColor[2],backgroundColor[3]]); } // var newarray = new Uint8Array(4*w*h); - var array = [] + var array = []; for (var n = oy; n < oy + h; n++) { var offsetValue = 4*w*n; if(n supress(pixels, pixel)); return pixels; -} +}; function supress(pixels, pixel) { @@ -84,7 +84,7 @@ function sobelFilter(pixels, x, y) { return { pixel: [val, val, val, grad], angle: angle - } + }; } function categorizeAngle(angle){ @@ -108,8 +108,8 @@ function isOutOfBounds(pixels, x, y){ const removeElem = (arr = [], elem) => { return arr = arr.filter((arrelem) => { return arrelem !== elem; - }) -} + }); +}; // Non Maximum Supression without interpolation function nonMaxSupress(pixels, grads, angles) { @@ -122,29 +122,29 @@ function nonMaxSupress(pixels, grads, angles) { if (!isOutOfBounds(pixels, x - 1, y - 1) && !isOutOfBounds(pixels, x+1, y+1)){ switch (angleCategory){ - case 1: - if (!((grads[x][y] >= grads[x][y + 1]) && (grads[x][y] >= grads[x][y - 1]))) { - pixelsToBeSupressed.push([x, y]); - } - break; + case 1: + if (!((grads[x][y] >= grads[x][y + 1]) && (grads[x][y] >= grads[x][y - 1]))) { + pixelsToBeSupressed.push([x, y]); + } + break; - case 2: - if (!((grads[x][y] >= grads[x + 1][y + 1]) && (grads[x][y] >= grads[x - 1][y - 1]))){ - pixelsToBeSupressed.push([x, y]); - } - break; + case 2: + if (!((grads[x][y] >= grads[x + 1][y + 1]) && (grads[x][y] >= grads[x - 1][y - 1]))){ + pixelsToBeSupressed.push([x, y]); + } + break; - case 3: - if (!((grads[x][y] >= grads[x + 1][y]) && (grads[x][y] >= grads[x - 1][y]))) { - pixelsToBeSupressed.push([x, y]); - } - break; + case 3: + if (!((grads[x][y] >= grads[x + 1][y]) && (grads[x][y] >= grads[x - 1][y]))) { + pixelsToBeSupressed.push([x, y]); + } + break; - case 4: - if (!((grads[x][y] >= grads[x + 1][y - 1]) && (grads[x][y] >= grads[x - 1][y + 1]))) { - pixelsToBeSupressed.push([x, y]); - } - break; + case 4: + if (!((grads[x][y] >= grads[x + 1][y - 1]) && (grads[x][y] >= grads[x - 1][y + 1]))) { + pixelsToBeSupressed.push([x, y]); + } + break; } } } @@ -154,7 +154,7 @@ function nonMaxSupress(pixels, grads, angles) { var convertToDegrees = radians => (radians * 180) / Math.PI; // Finds the max value in a 2d array like grads -var findMaxInMatrix = arr => Math.max(...arr.map(el => el.map(val => !!val ? val : 0)).map(el => Math.max(...el))); +var findMaxInMatrix = arr => Math.max(...arr.map(el => el.map(val => val ? val : 0)).map(el => Math.max(...el))); // Applies the double threshold to the image function doubleThreshold(pixels, highThresholdRatio, lowThresholdRatio, grads, strongEdgePixels, weakEdgePixels) { @@ -198,5 +198,5 @@ function hysteresis(strongEdgePixels, weakEdgePixels){ else if(weakEdgePixels.includes([x, y-1])) { removeElem(weakEdgePixels, [x, y-1]); } - }) + }); } diff --git a/src/modules/EdgeDetect/Module.js b/src/modules/EdgeDetect/Module.js index 1194a971..84d086ce 100644 --- a/src/modules/EdgeDetect/Module.js +++ b/src/modules/EdgeDetect/Module.js @@ -24,7 +24,7 @@ module.exports = function edgeDetect(options, UI) { return internalSequencer.loadImage(input.src, function () { internalSequencer.importJSON([{ 'name': 'blur', 'options': {blur: options.blur} }]); return internalSequencer.run(function onCallback(internalOutput) { - require('get-pixels')(internalOutput, function(err, blurPixels){ + require('get-pixels')(internalOutput, function(err, blurPixels){ if (err){ return; } @@ -51,7 +51,7 @@ module.exports = function edgeDetect(options, UI) { inBrowser: options.inBrowser, callback: callback }); - }) + }); }); }); } @@ -61,5 +61,5 @@ module.exports = function edgeDetect(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/EdgeDetect/index.js b/src/modules/EdgeDetect/index.js index 11ef888f..71549002 100644 --- a/src/modules/EdgeDetect/index.js +++ b/src/modules/EdgeDetect/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Exposure/Module.js b/src/modules/Exposure/Module.js index 4a160e53..01b94953 100644 --- a/src/modules/Exposure/Module.js +++ b/src/modules/Exposure/Module.js @@ -4,47 +4,47 @@ module.exports = function Exposure(options,UI){ - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - var output; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var output; - function draw(input,callback,progressObj){ + function draw(input,callback,progressObj){ - options.exposure = options.exposure || defaults.exposure - var exposure = Math.pow(2, options.exposure); - progressObj.stop(true); - progressObj.overrideFlag = true; + options.exposure = options.exposure || defaults.exposure; + var exposure = Math.pow(2, options.exposure); + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function changePixel(r, g, b, a){ + function changePixel(r, g, b, a){ - r = Math.min(255, r*exposure) - g = Math.min(255, g*exposure) - b = Math.min(255, b*exposure) - return [r, g, b, a] - } + r = Math.min(255, r*exposure); + g = Math.min(255, g*exposure); + b = Math.min(255, b*exposure); + return [r, g, b, a]; + } - function output(image,datauri,mimetype){ + function output(image,datauri,mimetype){ - // This output is accessible by Image Sequencer - step.output = {src:datauri,format:mimetype}; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = {src:datauri,format:mimetype}; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Exposure/index.js b/src/modules/Exposure/index.js index 11ef888f..71549002 100644 --- a/src/modules/Exposure/index.js +++ b/src/modules/Exposure/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/FisheyeGl/Module.js b/src/modules/FisheyeGl/Module.js index 7fc61a98..8c5b6e5c 100644 --- a/src/modules/FisheyeGl/Module.js +++ b/src/modules/FisheyeGl/Module.js @@ -18,14 +18,14 @@ module.exports = function DoNothing(options, UI) { // Create a canvas, if it doesn't already exist. if (!document.querySelector('#image-sequencer-canvas')) { var canvas = document.createElement('canvas'); - canvas.style.display = "none"; + canvas.style.display = 'none'; canvas.setAttribute('id', 'image-sequencer-canvas'); document.body.append(canvas); } else var canvas = document.querySelector('#image-sequencer-canvas'); distorter = FisheyeGl({ - selector: "#image-sequencer-canvas" + selector: '#image-sequencer-canvas' }); // Parse the inputs @@ -65,5 +65,5 @@ module.exports = function DoNothing(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/FisheyeGl/index.js b/src/modules/FisheyeGl/index.js index 11ef888f..71549002 100644 --- a/src/modules/FisheyeGl/index.js +++ b/src/modules/FisheyeGl/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/FlipImage/Module.js b/src/modules/FlipImage/Module.js index 4fea6991..96667a11 100644 --- a/src/modules/FlipImage/Module.js +++ b/src/modules/FlipImage/Module.js @@ -4,7 +4,7 @@ module.exports = function FlipImage(options, UI) { options.Axis = options.Axis || require('./info.json').inputs.Axis.default; - var output, + var output, getPixels = require('get-pixels'); function draw(input, callback, progressObj) { @@ -38,7 +38,7 @@ module.exports = function FlipImage(options, UI) { inBrowser: options.inBrowser, callback: callback }); - }) + }); } @@ -47,5 +47,5 @@ module.exports = function FlipImage(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/FlipImage/flipImage.js b/src/modules/FlipImage/flipImage.js index 9177c08c..b3280017 100644 --- a/src/modules/FlipImage/flipImage.js +++ b/src/modules/FlipImage/flipImage.js @@ -1,12 +1,12 @@ module.exports = function flipImage(oldPixels, pixels, axis) { - var width = oldPixels.shape[0], + var width = oldPixels.shape[0], height = oldPixels.shape[1]; function copyPixel(x1, y1, x2, y2){ - pixels.set(x1, y1, 0, oldPixels.get(x2, y2, 0)) - pixels.set(x1, y1, 1, oldPixels.get(x2, y2, 1)) - pixels.set(x1, y1, 2, oldPixels.get(x2, y2, 2)) - pixels.set(x1, y1, 3, oldPixels.get(x2, y2, 3)) + pixels.set(x1, y1, 0, oldPixels.get(x2, y2, 0)); + pixels.set(x1, y1, 1, oldPixels.get(x2, y2, 1)); + pixels.set(x1, y1, 2, oldPixels.get(x2, y2, 2)); + pixels.set(x1, y1, 3, oldPixels.get(x2, y2, 3)); } function flip(){ @@ -28,4 +28,4 @@ module.exports = function flipImage(oldPixels, pixels, axis) { flip(); return pixels; -} \ No newline at end of file +}; \ No newline at end of file diff --git a/src/modules/FlipImage/index.js b/src/modules/FlipImage/index.js index 11ef888f..71549002 100644 --- a/src/modules/FlipImage/index.js +++ b/src/modules/FlipImage/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/GammaCorrection/Module.js b/src/modules/GammaCorrection/Module.js index 137bf91f..463c81e5 100644 --- a/src/modules/GammaCorrection/Module.js +++ b/src/modules/GammaCorrection/Module.js @@ -1,47 +1,47 @@ module.exports = function Gamma(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - var defaults = require('./../../util/getDefaults.js')(require('./info.json')), - adjustment = options.adjustment || defaults.adjustment; - var val = adjustment / defaults.adjustment; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')), + adjustment = options.adjustment || defaults.adjustment; + var val = adjustment / defaults.adjustment; - function changePixel(r, g, b, a) { + function changePixel(r, g, b, a) { - r = Math.pow(r / 255, val) * 255; - g = Math.pow(g / 255, val) * 255; - b = Math.pow(b / 255, val) * 255; + r = Math.pow(r / 255, val) * 255; + g = Math.pow(g / 255, val) * 255; + b = Math.pow(b / 255, val) * 255; - return [r, g, b, a]; - } + return [r, g, b, a]; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/GammaCorrection/index.js b/src/modules/GammaCorrection/index.js index 11ef888f..71549002 100644 --- a/src/modules/GammaCorrection/index.js +++ b/src/modules/GammaCorrection/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Gradient/Module.js b/src/modules/Gradient/Module.js index 0c3baec3..12a00a9d 100644 --- a/src/modules/Gradient/Module.js +++ b/src/modules/Gradient/Module.js @@ -1,61 +1,61 @@ module.exports = function Invert(options, UI) { - var output; + var output; - // The function which is called on every draw. - function draw(input, callback, progressObj) { - var getPixels = require('get-pixels'); - var savePixels = require('save-pixels'); + // The function which is called on every draw. + function draw(input, callback, progressObj) { + var getPixels = require('get-pixels'); + var savePixels = require('save-pixels'); - var step = this; + var step = this; - getPixels(input.src, function(err, pixels) { + getPixels(input.src, function(err, pixels) { - if (err) { - console.log("Bad Image path"); - return; - } + if (err) { + console.log('Bad Image path'); + return; + } - var width = pixels.shape[0]; - - for (var i = 0; i < pixels.shape[0]; i++) { - for (var j = 0; j < pixels.shape[1]; j++) { - let val = (i / width) * 255; - pixels.set(i, j, 0, val); - pixels.set(i, j, 1, val); - pixels.set(i, j, 2, val); - pixels.set(i, j, 3, 255); - } - } - var chunks = []; - var totalLength = 0; - var r = savePixels(pixels, input.format, { quality: 100 }); - - r.on("data", function(chunk) { - totalLength += chunk.length; - chunks.push(chunk); - }); - - r.on("end", function() { - var data = Buffer.concat(chunks, totalLength).toString("base64"); - var datauri = "data:image/" + input.format + ";base64," + data; - output(input.image, datauri, input.format); - callback(); - }); - }); - - function output(image, datauri, mimetype) { - - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; + var width = pixels.shape[0]; + for (var i = 0; i < pixels.shape[0]; i++) { + for (var j = 0; j < pixels.shape[1]; j++) { + let val = (i / width) * 255; + pixels.set(i, j, 0, val); + pixels.set(i, j, 1, val); + pixels.set(i, j, 2, val); + pixels.set(i, j, 3, 255); } - } + } + var chunks = []; + var totalLength = 0; + var r = savePixels(pixels, input.format, { quality: 100 }); + + r.on('data', function(chunk) { + totalLength += chunk.length; + chunks.push(chunk); + }); + + r.on('end', function() { + var data = Buffer.concat(chunks, totalLength).toString('base64'); + var datauri = 'data:image/' + input.format + ';base64,' + data; + output(input.image, datauri, input.format); + callback(); + }); + }); + + function output(image, datauri, mimetype) { + + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; - return { - options: options, - draw: draw, - output: output, - UI: UI } -} + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Gradient/index.js b/src/modules/Gradient/index.js index 11ef888f..71549002 100644 --- a/src/modules/Gradient/index.js +++ b/src/modules/Gradient/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/GridOverlay/GridOverlay.js b/src/modules/GridOverlay/GridOverlay.js index 628c5c26..884076b1 100644 --- a/src/modules/GridOverlay/GridOverlay.js +++ b/src/modules/GridOverlay/GridOverlay.js @@ -1,28 +1,28 @@ module.exports = exports = function(pixels, options){ - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.x = Number(options.x) || defaults.x; - options.y = Number(options.y) || defaults.y; - color = options.color || defaults.color; - color = color.split(" "); + options.x = Number(options.x) || defaults.x; + options.y = Number(options.y) || defaults.y; + color = options.color || defaults.color; + color = color.split(' '); - for(var x = 0; x < pixels.shape[0]; x+=options.x){ - for(var y = 0 ; y < pixels.shape[1]; y++){ - pixels.set(x, y, 0, color[0]); - pixels.set(x, y, 1, color[1]); - pixels.set(x, y, 2, color[2]); - pixels.set(x, y, 3, color[3]); - } - } + for(var x = 0; x < pixels.shape[0]; x+=options.x){ + for(var y = 0 ; y < pixels.shape[1]; y++){ + pixels.set(x, y, 0, color[0]); + pixels.set(x, y, 1, color[1]); + pixels.set(x, y, 2, color[2]); + pixels.set(x, y, 3, color[3]); + } + } - for(var y = 0; y < pixels.shape[1]; y+=options.y){ - for(var x = 0 ; x < pixels.shape[0]; x++){ - pixels.set(x, y, 0, color[0]); - pixels.set(x, y, 1, color[1]); - pixels.set(x, y, 2, color[2]); - pixels.set(x, y, 3, color[3]); - } - } + for(var y = 0; y < pixels.shape[1]; y+=options.y){ + for(var x = 0 ; x < pixels.shape[0]; x++){ + pixels.set(x, y, 0, color[0]); + pixels.set(x, y, 1, color[1]); + pixels.set(x, y, 2, color[2]); + pixels.set(x, y, 3, color[3]); + } + } - return pixels; -} + return pixels; +}; diff --git a/src/modules/GridOverlay/Module.js b/src/modules/GridOverlay/Module.js index 5d9ef3df..150518b2 100644 --- a/src/modules/GridOverlay/Module.js +++ b/src/modules/GridOverlay/Module.js @@ -11,9 +11,9 @@ module.exports = function GridOverlay(options,UI) { var step = this; function extraManipulation(pixels) { - pixels = require('./GridOverlay')(pixels, options); - return pixels - } + pixels = require('./GridOverlay')(pixels, options); + return pixels; + } function output(image, datauri, mimetype) { @@ -32,12 +32,12 @@ module.exports = function GridOverlay(options,UI) { }); - } + } return { options: options, draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/GridOverlay/index.js b/src/modules/GridOverlay/index.js index 11ef888f..71549002 100644 --- a/src/modules/GridOverlay/index.js +++ b/src/modules/GridOverlay/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Histogram/Module.js b/src/modules/Histogram/Module.js index 8f22e112..eb8e3fea 100644 --- a/src/modules/Histogram/Module.js +++ b/src/modules/Histogram/Module.js @@ -3,92 +3,92 @@ */ module.exports = function Channel(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.gradient = options.gradient || defaults.gradient; - options.gradient = JSON.parse(options.gradient); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.gradient = options.gradient || defaults.gradient; + options.gradient = JSON.parse(options.gradient); - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this, hist = new Array(256).fill(0); + var step = this, hist = new Array(256).fill(0); - function changePixel(r, g, b, a) { - let pixVal = Math.round((r + g + b) / 3); - hist[pixVal]++; - return [r, g, b, a]; + function changePixel(r, g, b, a) { + let pixVal = Math.round((r + g + b) / 3); + hist[pixVal]++; + return [r, g, b, a]; + } + + function extraManipulation(pixels) { + // if (!options.inBrowser) + // require('fs').writeFileSync('./output/histo.txt', hist.reduce((tot, cur, idx) => `${tot}\n${idx} : ${cur}`, ``)); + var newarray = new Uint8Array(4 * 256 * 256); + pixels.data = newarray; + pixels.shape = [256, 256, 4]; + pixels.stride[1] = 4 * 256; + + for (let x = 0; x < 256; x++) { + for (let y = 0; y < 256; y++) { + pixels.set(x, y, 0, 255); + pixels.set(x, y, 1, 255); + pixels.set(x, y, 2, 255); + pixels.set(x, y, 3, 255); } + } - function extraManipulation(pixels) { - // if (!options.inBrowser) - // require('fs').writeFileSync('./output/histo.txt', hist.reduce((tot, cur, idx) => `${tot}\n${idx} : ${cur}`, ``)); - var newarray = new Uint8Array(4 * 256 * 256); - pixels.data = newarray; - pixels.shape = [256, 256, 4]; - pixels.stride[1] = 4 * 256; - - for (let x = 0; x < 256; x++) { - for (let y = 0; y < 256; y++) { - pixels.set(x, y, 0, 255); - pixels.set(x, y, 1, 255); - pixels.set(x, y, 2, 255); - pixels.set(x, y, 3, 255); - } - } - - let startY = options.gradient ? 10 : 0; - if (options.gradient) { - for (let x = 0; x < 256; x++) { - for (let y = 0; y < 10; y++) { - pixels.set(x, 255 - y, 0, x); - pixels.set(x, 255 - y, 1, x); - pixels.set(x, 255 - y, 2, x); - } - } - } - - let convfactor = (256 - startY) / Math.max(...hist); - - for (let x = 0; x < 256; x++) { - let pixCount = Math.round(convfactor * hist[x]); - - for (let y = startY; y < pixCount; y++) { - pixels.set(x, 255 - y, 0, 204); - pixels.set(x, 255 - y, 1, 255); - pixels.set(x, 255 - y, 2, 153); - } - } - - return pixels; + let startY = options.gradient ? 10 : 0; + if (options.gradient) { + for (let x = 0; x < 256; x++) { + for (let y = 0; y < 10; y++) { + pixels.set(x, 255 - y, 0, x); + pixels.set(x, 255 - y, 1, x); + pixels.set(x, 255 - y, 2, x); + } } + } - function output(image, datauri, mimetype) { + let convfactor = (256 - startY) / Math.max(...hist); - // This output is accesible by Image Sequencer - step.output = { src: datauri, format: mimetype }; + for (let x = 0; x < 256; x++) { + let pixCount = Math.round(convfactor * hist[x]); + for (let y = startY; y < pixCount; y++) { + pixels.set(x, 255 - y, 0, 204); + pixels.set(x, 255 - y, 1, 255); + pixels.set(x, 255 - y, 2, 153); } + } - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + return pixels; + } + + function output(image, datauri, mimetype) { + + // This output is accesible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - //setup: setup, // optional - draw: draw, - output: output, - UI: UI - } -} + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + + } + + return { + options: options, + //setup: setup, // optional + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Histogram/index.js b/src/modules/Histogram/index.js index 6406746a..eb9d69a7 100644 --- a/src/modules/Histogram/index.js +++ b/src/modules/Histogram/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module.js'), - require('./info.json') -] \ No newline at end of file + require('./Module.js'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/ImportImage/Module.js b/src/modules/ImportImage/Module.js index 4485ed4d..03ea721f 100644 --- a/src/modules/ImportImage/Module.js +++ b/src/modules/ImportImage/Module.js @@ -9,7 +9,7 @@ module.exports = function ImportImageModule(options, UI) { var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.imageUrl = options.inBrowser ? (options.url || defaults.url) : "./examples/images/monarch.png"; + options.imageUrl = options.inBrowser ? (options.url || defaults.url) : './examples/images/monarch.png'; var output; @@ -44,5 +44,5 @@ module.exports = function ImportImageModule(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/ImportImage/Ui.js b/src/modules/ImportImage/Ui.js index 7523e665..6c1f1fa1 100644 --- a/src/modules/ImportImage/Ui.js +++ b/src/modules/ImportImage/Ui.js @@ -25,14 +25,14 @@ module.exports = function ImportImageModuleUi(step, ui) { // setup file input listener sequencer.setInputStep({ - dropZoneSelector: "#" + dropzoneId, - fileInputSelector: "#" + dropzoneId + " .file-input", + dropZoneSelector: '#' + dropzoneId, + fileInputSelector: '#' + dropzoneId + ' .file-input', onLoad: function onLoadFromInput(progress) { var reader = progress.target; step.options.imageUrl = reader.result; step.options.url = reader.result; sequencer.run(); - setUrlHashParameter("steps", sequencer.toString()); + setUrlHashParameter('steps', sequencer.toString()); } }); @@ -44,11 +44,11 @@ module.exports = function ImportImageModuleUi(step, ui) { step.options.imageUrl = src; sequencer.run(); - }); + }); } return { setup: setup - } -} + }; +}; diff --git a/src/modules/ImportImage/index.js b/src/modules/ImportImage/index.js index 11ef888f..71549002 100644 --- a/src/modules/ImportImage/index.js +++ b/src/modules/ImportImage/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Invert/Module.js b/src/modules/Invert/Module.js index 8d8c4d23..e5c4d406 100644 --- a/src/modules/Invert/Module.js +++ b/src/modules/Invert/Module.js @@ -40,12 +40,12 @@ function Invert(options, UI) { draw: draw, output: output, UI: UI - } + }; } var info = { - "name": "Invert", - "description": "Inverts the image.", - "inputs": { + 'name': 'Invert', + 'description': 'Inverts the image.', + 'inputs': { } -} +}; module.exports = [Invert, info]; diff --git a/src/modules/Ndvi/Module.js b/src/modules/Ndvi/Module.js index 15cf74bb..d599ec06 100644 --- a/src/modules/Ndvi/Module.js +++ b/src/modules/Ndvi/Module.js @@ -19,8 +19,8 @@ module.exports = function Ndvi(options, UI) { var step = this; function changePixel(r, g, b, a) { - if (options.filter == "red") var ndvi = (b - r) / (1.00 * b + r); - if (options.filter == "blue") var ndvi = (r - b) / (1.00 * b + r); + if (options.filter == 'red') var ndvi = (b - r) / (1.00 * b + r); + if (options.filter == 'blue') var ndvi = (r - b) / (1.00 * b + r); var x = 255 * (ndvi + 1) / 2; return [x, x, x, a]; } @@ -55,5 +55,5 @@ module.exports = function Ndvi(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/Ndvi/Ui.js b/src/modules/Ndvi/Ui.js index 349460cb..d27d39ec 100644 --- a/src/modules/Ndvi/Ui.js +++ b/src/modules/Ndvi/Ui.js @@ -1,34 +1,34 @@ // hide on save module.exports = function CropModuleUi(step, ui) { - /* sets the pixel value under the mouse pointer + /* sets the pixel value under the mouse pointer * on the title attribute of the image element. */ - function setup() { - var ndviImage = $(imgEl()); + function setup() { + var ndviImage = $(imgEl()); - ndviImage.mousemove(function ndviMousemove(e) { + ndviImage.mousemove(function ndviMousemove(e) { - var canvas = document.createElement("canvas"); - canvas.width = ndviImage.width(); - canvas.height = ndviImage.height(); - canvas.getContext('2d').drawImage(this, 0, 0); + var canvas = document.createElement('canvas'); + canvas.width = ndviImage.width(); + canvas.height = ndviImage.height(); + canvas.getContext('2d').drawImage(this, 0, 0); - var offset = $(this).offset(); - var xPos = e.pageX - offset.left; - var yPos = e.pageY - offset.top; - var ndvi = canvas.getContext('2d').getImageData(xPos, yPos, 1, 1).data[0]; - ndvi = ndvi/127.5 - 1 ; - ndvi = ndvi.toFixed(2); - ndviImage[0].title = "NDVI: " + ndvi; - }); - } - // step.imgSelector is not defined, imgElement is: - function imgEl() { - return step.imgElement; - } + var offset = $(this).offset(); + var xPos = e.pageX - offset.left; + var yPos = e.pageY - offset.top; + var ndvi = canvas.getContext('2d').getImageData(xPos, yPos, 1, 1).data[0]; + ndvi = ndvi/127.5 - 1 ; + ndvi = ndvi.toFixed(2); + ndviImage[0].title = 'NDVI: ' + ndvi; + }); + } + // step.imgSelector is not defined, imgElement is: + function imgEl() { + return step.imgElement; + } - return { - setup: setup - } -} + return { + setup: setup + }; +}; diff --git a/src/modules/Ndvi/index.js b/src/modules/Ndvi/index.js index 11ef888f..71549002 100644 --- a/src/modules/Ndvi/index.js +++ b/src/modules/Ndvi/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/NdviColormap/Module.js b/src/modules/NdviColormap/Module.js index cd5356f1..4ad489b6 100644 --- a/src/modules/NdviColormap/Module.js +++ b/src/modules/NdviColormap/Module.js @@ -2,13 +2,13 @@ * Sample Meta Module for demonstration purpose only */ module.exports = require('../../util/createMetaModule.js')( - function mapFunction(options) { + function mapFunction(options) { - return [ - { 'name': 'ndvi', 'options': {} }, - { 'name': 'colormap', 'options': { colormap: options.colormap } }, - ]; - }, { - infoJson: require('./info.json') - } + return [ + { 'name': 'ndvi', 'options': {} }, + { 'name': 'colormap', 'options': { colormap: options.colormap } }, + ]; + }, { + infoJson: require('./info.json') + } )[0]; \ No newline at end of file diff --git a/src/modules/NdviColormap/index.js b/src/modules/NdviColormap/index.js index 11ef888f..71549002 100644 --- a/src/modules/NdviColormap/index.js +++ b/src/modules/NdviColormap/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Overlay/Module.js b/src/modules/Overlay/Module.js index 43cb9955..85ba59cf 100644 --- a/src/modules/Overlay/Module.js +++ b/src/modules/Overlay/Module.js @@ -1,83 +1,83 @@ module.exports = function Dynamic(options, UI, util) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.x = options.x || defaults.x; - options.y = options.y || defaults.y; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.x = options.x || defaults.x; + options.y = options.y || defaults.y; - var output; + var output; - // This function is called on every draw. - function draw(input, callback, progressObj) { + // This function is called on every draw. + function draw(input, callback, progressObj) { - options.offset = options.offset || -2; + options.offset = options.offset || -2; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - var parseCornerCoordinateInputs = require('../../util/ParseInputCoordinates'); + var parseCornerCoordinateInputs = require('../../util/ParseInputCoordinates'); - //parse the inputs - parseCornerCoordinateInputs(options, { - src: input.src, - x: { valInp: options.x, type: 'horizontal' }, - y: { valInp: options.y, type: 'vertical' }, - }, function (options, input) { - options.x = parseInt(input.x.valInp); - options.y = parseInt(input.y.valInp); - }); + //parse the inputs + parseCornerCoordinateInputs(options, { + src: input.src, + x: { valInp: options.x, type: 'horizontal' }, + y: { valInp: options.y, type: 'vertical' }, + }, function (options, input) { + options.x = parseInt(input.x.valInp); + options.y = parseInt(input.y.valInp); + }); - // save the pixels of the base image - var baseStepImage = this.getStep(options.offset).image; - var baseStepOutput = this.getOutput(options.offset); + // save the pixels of the base image + var baseStepImage = this.getStep(options.offset).image; + var baseStepOutput = this.getOutput(options.offset); - var getPixels = require('get-pixels'); + var getPixels = require('get-pixels'); - getPixels(input.src, function (err, pixels) { - options.secondImagePixels = pixels; + getPixels(input.src, function (err, pixels) { + options.secondImagePixels = pixels; - function changePixel(r1, g1, b1, a1, x, y) { + function changePixel(r1, g1, b1, a1, x, y) { - // overlay - var p = options.secondImagePixels; - if (x >= options.x + // overlay + var p = options.secondImagePixels; + if (x >= options.x && x < p.shape[0] && y >= options.y && y < p.shape[1]) - return [ - p.get(x, y, 0), - p.get(x, y, 1), - p.get(x, y, 2), - p.get(x, y, 3) - ]; - else - return [r1, g1, b1, a1]; - } + return [ + p.get(x, y, 0), + p.get(x, y, 1), + p.get(x, y, 2), + p.get(x, y, 3) + ]; + else + return [r1, g1, b1, a1]; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; - } + } - // run PixelManipulation on first Image pixels - return require('../_nomodule/PixelManipulation.js')(baseStepOutput, { - output: output, - changePixel: changePixel, - format: baseStepOutput.format, - image: baseStepImage, - inBrowser: options.inBrowser, - callback: callback - }); - }); - } - - return { - options: options, - draw: draw, + // run PixelManipulation on first Image pixels + return require('../_nomodule/PixelManipulation.js')(baseStepOutput, { output: output, - UI: UI - } -} + changePixel: changePixel, + format: baseStepOutput.format, + image: baseStepImage, + inBrowser: options.inBrowser, + callback: callback + }); + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Overlay/index.js b/src/modules/Overlay/index.js index 11ef888f..71549002 100644 --- a/src/modules/Overlay/index.js +++ b/src/modules/Overlay/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/PaintBucket/Module.js b/src/modules/PaintBucket/Module.js index b63c8d7d..e720a535 100644 --- a/src/modules/PaintBucket/Module.js +++ b/src/modules/PaintBucket/Module.js @@ -1,40 +1,40 @@ module.exports = function PaintBucket(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { + function extraManipulation(pixels) { - pixels = require('./PaintBucket')(pixels, options) - return pixels + pixels = require('./PaintBucket')(pixels, options); + return pixels; - } - - function output(image, datauri, mimetype) { - // This output is accesible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); } - return { - options: options, - draw: draw, - output: output, - UI: UI + function output(image, datauri, mimetype) { + // This output is accesible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/PaintBucket/PaintBucket.js b/src/modules/PaintBucket/PaintBucket.js index 6cebaeb5..51573939 100644 --- a/src/modules/PaintBucket/PaintBucket.js +++ b/src/modules/PaintBucket/PaintBucket.js @@ -22,7 +22,7 @@ module.exports = exports = function(pixels, options) { maxFactor = (1 + tolerance / 100), minFactor = (1 - tolerance / 100); - fillColor = fillColor.split(" "); + fillColor = fillColor.split(' '); function isSimilar(currx, curry) { return (pixels.get(currx, curry, 0) >= r * minFactor && pixels.get(currx, curry, 0) <= r * maxFactor && pixels.get(currx, curry, 1) >= g * minFactor && pixels.get(currx, curry, 1) <= g * maxFactor && @@ -31,19 +31,19 @@ module.exports = exports = function(pixels, options) { } while (queuey.length) { - currx = queuex.pop() - curry = queuey.pop() + currx = queuex.pop(); + curry = queuey.pop(); if (isSimilar(currx, curry)) { - north = south = curry + north = south = curry; do { - north -= 1 - } while (isSimilar(currx, north) && north >= 0) + north -= 1; + } while (isSimilar(currx, north) && north >= 0); do { - south += 1 - } while (isSimilar(currx, south) && south < height) + south += 1; + } while (isSimilar(currx, south) && south < height); for (n = north + 1; n < south; n += 1) { pixels.set(currx, n, 0, fillColor[0]); @@ -51,16 +51,16 @@ module.exports = exports = function(pixels, options) { pixels.set(currx, n, 2, fillColor[2]); pixels.set(currx, n, 3, fillColor[3]); if (isSimilar(currx - 1, n)) { - queuex.push(currx - 1) - queuey.push(n) + queuex.push(currx - 1); + queuey.push(n); } if (isSimilar(currx + 1, n)) { - queuex.push(currx + 1) - queuey.push(n) + queuex.push(currx + 1); + queuey.push(n); } } } } return pixels; -} +}; diff --git a/src/modules/PaintBucket/index.js b/src/modules/PaintBucket/index.js index 11ef888f..71549002 100644 --- a/src/modules/PaintBucket/index.js +++ b/src/modules/PaintBucket/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/ReplaceColor/Module.js b/src/modules/ReplaceColor/Module.js index 6c3a76b9..cfb944f1 100644 --- a/src/modules/ReplaceColor/Module.js +++ b/src/modules/ReplaceColor/Module.js @@ -1,44 +1,44 @@ module.exports = function ReplaceColor(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function changePixel(r, g, b, a) { - return [r, g, b, a] - } + function changePixel(r, g, b, a) { + return [r, g, b, a]; + } - function extraManipulation(pixels) { - pixels = require('./ReplaceColor')(pixels, options) - return pixels - } + function extraManipulation(pixels) { + pixels = require('./ReplaceColor')(pixels, options); + return pixels; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/ReplaceColor/ReplaceColor.js b/src/modules/ReplaceColor/ReplaceColor.js index 16f3d935..3dca4293 100644 --- a/src/modules/ReplaceColor/ReplaceColor.js +++ b/src/modules/ReplaceColor/ReplaceColor.js @@ -1,43 +1,43 @@ module.exports = exports = function(pixels, options){ - var color = options.color || '228 86 81'; - var replaceColor = options.replaceColor || '0 0 255'; - var replaceMethod = options.replaceMethod || 'greyscale'; - color = color.split(' '); - replaceColor = replaceColor.split(' '); + var color = options.color || '228 86 81'; + var replaceColor = options.replaceColor || '0 0 255'; + var replaceMethod = options.replaceMethod || 'greyscale'; + color = color.split(' '); + replaceColor = replaceColor.split(' '); - var cr = color[0], - cg = color[1], - cb = color[2]; + var cr = color[0], + cg = color[1], + cb = color[2]; - var tolerance = options.tolerance || 50; - var maxFactor = (1 + tolerance/100); - var minFactor = (1 - tolerance/100); + var tolerance = options.tolerance || 50; + var maxFactor = (1 + tolerance/100); + var minFactor = (1 - tolerance/100); - function isSimilar(r, g, b){ - return ( r >= cr*minFactor && r <= cr*maxFactor && + function isSimilar(r, g, b){ + return ( r >= cr*minFactor && r <= cr*maxFactor && g >= cg*minFactor && g <= cg*maxFactor && b >= cb*minFactor && b <= cb*maxFactor); - } + } - for(var i = 0; i < pixels.shape[0]; i++){ - for(var j = 0; j < pixels.shape[1]; j++){ - var r = pixels.get(i,j,0), - g = pixels.get(i,j,1), - b = pixels.get(i,j,2); - if(isSimilar(r,g,b)){ - if (replaceMethod == "greyscale"){ - var avg = (r + g + b)/3; - pixels.set(i,j,0,avg); - pixels.set(i,j,1,avg); - pixels.set(i,j,2,avg); - }else { - pixels.set(i,j,0,replaceColor[0]); - pixels.set(i,j,1,replaceColor[1]); - pixels.set(i,j,2,replaceColor[2]); - } - } + for(var i = 0; i < pixels.shape[0]; i++){ + for(var j = 0; j < pixels.shape[1]; j++){ + var r = pixels.get(i,j,0), + g = pixels.get(i,j,1), + b = pixels.get(i,j,2); + if(isSimilar(r,g,b)){ + if (replaceMethod == 'greyscale'){ + var avg = (r + g + b)/3; + pixels.set(i,j,0,avg); + pixels.set(i,j,1,avg); + pixels.set(i,j,2,avg); + }else { + pixels.set(i,j,0,replaceColor[0]); + pixels.set(i,j,1,replaceColor[1]); + pixels.set(i,j,2,replaceColor[2]); } + } } - return pixels; -} \ No newline at end of file + } + return pixels; +}; \ No newline at end of file diff --git a/src/modules/ReplaceColor/index.js b/src/modules/ReplaceColor/index.js index 11ef888f..71549002 100644 --- a/src/modules/ReplaceColor/index.js +++ b/src/modules/ReplaceColor/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Resize/Module.js b/src/modules/Resize/Module.js index 23b3a645..66a54e21 100644 --- a/src/modules/Resize/Module.js +++ b/src/modules/Resize/Module.js @@ -3,70 +3,70 @@ */ module.exports = function Resize(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.resize = options.resize || defaults.resize; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.resize = options.resize || defaults.resize; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - var imagejs = require('imagejs'); + var imagejs = require('imagejs'); - function changePixel(r, g, b, a) { - return [r, g, b, a] - } - - function extraManipulation(pixels) { - // value above 100% scales up, and below 100% scales down - var resize_value = parseInt(options.resize.slice(0, -1)); - - var new_width, - new_height; - - new_width = Math.round(pixels.shape[0] * (resize_value / 100)); - new_height = Math.round(pixels.shape[1] * (resize_value / 100)); - - var bitmap = new imagejs.Bitmap({width: pixels.shape[0], height: pixels.shape[1]}); - bitmap._data.data = pixels.data; - - - var resized = bitmap.resize({ - width: new_width, height: new_height, - algorithm: "bicubicInterpolation" - }); - - pixels.data = resized._data.data; - pixels.shape = [new_width,new_height,4]; - pixels.stride[1] = 4 * new_width; - - return pixels; - } - - function output(image, datauri, mimetype) { - // This output is accesible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + function changePixel(r, g, b, a) { + return [r, g, b, a]; } - return { - options: options, - draw: draw, - output: output, - UI: UI + function extraManipulation(pixels) { + // value above 100% scales up, and below 100% scales down + var resize_value = parseInt(options.resize.slice(0, -1)); + + var new_width, + new_height; + + new_width = Math.round(pixels.shape[0] * (resize_value / 100)); + new_height = Math.round(pixels.shape[1] * (resize_value / 100)); + + var bitmap = new imagejs.Bitmap({width: pixels.shape[0], height: pixels.shape[1]}); + bitmap._data.data = pixels.data; + + + var resized = bitmap.resize({ + width: new_width, height: new_height, + algorithm: 'bicubicInterpolation' + }); + + pixels.data = resized._data.data; + pixels.shape = [new_width,new_height,4]; + pixels.stride[1] = 4 * new_width; + + return pixels; } -} + + function output(image, datauri, mimetype) { + // This output is accesible by Image Sequencer + step.output = { src: datauri, format: mimetype }; + } + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Resize/index.js b/src/modules/Resize/index.js index 11ef888f..71549002 100644 --- a/src/modules/Resize/index.js +++ b/src/modules/Resize/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Rotate/Module.js b/src/modules/Rotate/Module.js index 23a7cb1b..f578a07f 100644 --- a/src/modules/Rotate/Module.js +++ b/src/modules/Rotate/Module.js @@ -3,61 +3,61 @@ */ module.exports = function Rotate(options, UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.rotate = options.rotate || defaults.rotate; + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + options.rotate = options.rotate || defaults.rotate; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - var imagejs = require('imagejs'); + var imagejs = require('imagejs'); - function changePixel(r, g, b, a) { - return [r, g, b, a] - } + function changePixel(r, g, b, a) { + return [r, g, b, a]; + } - function extraManipulation(pixels) { - var rotate_value = (options.rotate)%360; + function extraManipulation(pixels) { + var rotate_value = (options.rotate)%360; - if(rotate_value%360 == 0) - return pixels; + if(rotate_value%360 == 0) + return pixels; - var bitmap = new imagejs.Bitmap({width: pixels.shape[0], height: pixels.shape[1]}); - bitmap._data.data = pixels.data; + var bitmap = new imagejs.Bitmap({width: pixels.shape[0], height: pixels.shape[1]}); + bitmap._data.data = pixels.data; - var rotated = bitmap.rotate({ - degrees: rotate_value, - }); - pixels.data = rotated._data.data; + var rotated = bitmap.rotate({ + degrees: rotate_value, + }); + pixels.data = rotated._data.data; - return pixels; - } - - function output(image, datauri, mimetype) { - // This output is accesible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + return pixels; } - return { - options: options, - draw: draw, - output: output, - UI: UI + function output(image, datauri, mimetype) { + // This output is accesible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Rotate/index.js b/src/modules/Rotate/index.js index 11ef888f..71549002 100644 --- a/src/modules/Rotate/index.js +++ b/src/modules/Rotate/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Saturation/Module.js b/src/modules/Saturation/Module.js index 5e73633c..5a62bc51 100644 --- a/src/modules/Saturation/Module.js +++ b/src/modules/Saturation/Module.js @@ -3,7 +3,7 @@ */ module.exports = function Saturation(options,UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); var output; function draw(input, callback, progressObj) { @@ -55,5 +55,5 @@ module.exports = function Saturation(options,UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/Saturation/index.js b/src/modules/Saturation/index.js index 11ef888f..71549002 100644 --- a/src/modules/Saturation/index.js +++ b/src/modules/Saturation/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/TextOverlay/Module.js b/src/modules/TextOverlay/Module.js index 8570958b..ed13b1aa 100644 --- a/src/modules/TextOverlay/Module.js +++ b/src/modules/TextOverlay/Module.js @@ -1,51 +1,51 @@ module.exports = function TextOverlay(options,UI) { - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; - if (!options.step.inBrowser) { // This module is only for browser - this.output = input; - callback(); - } - else{ - var priorStep = this.getStep(-1); // get the previous step to add text onto it. + var step = this; + if (!options.step.inBrowser) { // This module is only for browser + this.output = input; + callback(); + } + else{ + var priorStep = this.getStep(-1); // get the previous step to add text onto it. - function extraManipulation(pixels) { + function extraManipulation(pixels) { //if (options.step.inBrowser) pixels = require('./TextOverlay')(pixels, options,priorStep); - return pixels + return pixels; } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accesible by Image Sequencer - step.output = { src: datauri, format: mimetype }; + // This output is accesible by Image Sequencer + step.output = { src: datauri, format: mimetype }; - } + } - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); - } } + } - return { - options: options, - draw: draw, - output: output, - UI: UI - } - } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; \ No newline at end of file diff --git a/src/modules/TextOverlay/TextOverlay.js b/src/modules/TextOverlay/TextOverlay.js index 8e9de056..2cb7c3a1 100644 --- a/src/modules/TextOverlay/TextOverlay.js +++ b/src/modules/TextOverlay/TextOverlay.js @@ -1,27 +1,27 @@ module.exports = exports = function(pixels, options,priorstep){ - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.text = options.text || defaults.text; - options.x = options.x || defaults.x; - options.y = options.y || defaults.y; - options.font = options.font || defaults.font; - options.color = options.color || defaults.color; - options.size = options.size || defaults.size; + options.text = options.text || defaults.text; + options.x = options.x || defaults.x; + options.y = options.y || defaults.y; + options.font = options.font || defaults.font; + options.color = options.color || defaults.color; + options.size = options.size || defaults.size; - var img = $(priorstep.imgElement); - if(Object.keys(img).length === 0){ - img = $(priorstep.options.step.imgElement); - } - var canvas = document.createElement("canvas"); - canvas.width = pixels.shape[0]; //img.width(); - canvas.height = pixels.shape[1]; //img.height(); - var ctx = canvas.getContext('2d'); - ctx.drawImage(img[0], 0, 0); - ctx.fillStyle = options.color; - ctx.font = options.size +"px " + options.font; - ctx.fillText(options.text, options.x, options.y); + var img = $(priorstep.imgElement); + if(Object.keys(img).length === 0){ + img = $(priorstep.options.step.imgElement); + } + var canvas = document.createElement('canvas'); + canvas.width = pixels.shape[0]; //img.width(); + canvas.height = pixels.shape[1]; //img.height(); + var ctx = canvas.getContext('2d'); + ctx.drawImage(img[0], 0, 0); + ctx.fillStyle = options.color; + ctx.font = options.size +'px ' + options.font; + ctx.fillText(options.text, options.x, options.y); - var myImageData = ctx.getImageData(0,0,canvas.width,canvas.height); - pixels.data = myImageData.data - return pixels; -} \ No newline at end of file + var myImageData = ctx.getImageData(0,0,canvas.width,canvas.height); + pixels.data = myImageData.data; + return pixels; +}; \ No newline at end of file diff --git a/src/modules/TextOverlay/index.js b/src/modules/TextOverlay/index.js index 11ef888f..71549002 100644 --- a/src/modules/TextOverlay/index.js +++ b/src/modules/TextOverlay/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Threshold/Module.js b/src/modules/Threshold/Module.js index 32732d68..f05479b5 100644 --- a/src/modules/Threshold/Module.js +++ b/src/modules/Threshold/Module.js @@ -19,8 +19,8 @@ module.exports = function ImageThreshold(options, UI) { } function extraManipulation(pixels) { - pixels = require('./Threshold')(pixels, options, hist) - return pixels + pixels = require('./Threshold')(pixels, options, hist); + return pixels; } function output(image, datauri, mimetype) { // This output is accessible by Image Sequencer @@ -40,5 +40,5 @@ module.exports = function ImageThreshold(options, UI) { draw: draw, output: output, UI: UI - } -} + }; +}; diff --git a/src/modules/Threshold/Threshold.js b/src/modules/Threshold/Threshold.js index 1ba23808..8fe1dfcb 100644 --- a/src/modules/Threshold/Threshold.js +++ b/src/modules/Threshold/Threshold.js @@ -1,69 +1,69 @@ module.exports = function Threshold(pixels, options, histData) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - type = options.threshold ; - threshold = parseInt(options.input) || defaults.input; - var lumR = []; - var lumG = []; - var lumB = []; - for (var i = 0; i < 256; i++) { - lumR[i] = i * 0.299; - lumG[i] = i * 0.587; - lumB[i] = i * 0.114; - } + type = options.threshold ; + threshold = parseInt(options.input) || defaults.input; + var lumR = []; + var lumG = []; + var lumB = []; + for (var i = 0; i < 256; i++) { + lumR[i] = i * 0.299; + lumG[i] = i * 0.587; + lumB[i] = i * 0.114; + } - var imageDataLength = pixels.data.length; //imageData.data.length; - for (var i = 0; i <= imageDataLength; i++) { - pixels.data[i] = Math.floor(lumR[pixels.data[i++]] + lumG[pixels.data[i++]] + lumB[pixels.data[i++]]); - } + var imageDataLength = pixels.data.length; //imageData.data.length; + for (var i = 0; i <= imageDataLength; i++) { + pixels.data[i] = Math.floor(lumR[pixels.data[i++]] + lumG[pixels.data[i++]] + lumB[pixels.data[i++]]); + } - if (type === "Automatic Thresholding") - threshold = otsu(histData); + if (type === 'Automatic Thresholding') + threshold = otsu(histData); - for (var currentPixel = 0; currentPixel <= imageDataLength; currentPixel += 4) { + for (var currentPixel = 0; currentPixel <= imageDataLength; currentPixel += 4) { - pixels.data[currentPixel] = pixels.data[currentPixel] < threshold ? 0 : 255; - pixels.data[currentPixel + 1] = pixels.data[currentPixel + 2] = pixels.data[currentPixel]; - } - return pixels; -} + pixels.data[currentPixel] = pixels.data[currentPixel] < threshold ? 0 : 255; + pixels.data[currentPixel + 1] = pixels.data[currentPixel + 2] = pixels.data[currentPixel]; + } + return pixels; +}; function otsu(histData) { - let total = 0; - for (let t = 0; t < 256; t++) total += histData[t]; + let total = 0; + for (let t = 0; t < 256; t++) total += histData[t]; - let sum = 0; - for (let t = 0; t < 256; t++) sum += t * histData[t]; + let sum = 0; + for (let t = 0; t < 256; t++) sum += t * histData[t]; - let sumB = 0; - let wB = 0; - let wF = 0; + let sumB = 0; + let wB = 0; + let wF = 0; - let varMax = 0; - let threshold = 0; + let varMax = 0; + let threshold = 0; - for (let t = 0; t < 256; t++) { - wB += histData[t]; // Weight Background - if (wB == 0) continue; + for (let t = 0; t < 256; t++) { + wB += histData[t]; // Weight Background + if (wB == 0) continue; - wF = total - wB; // Weight Foreground - if (wF == 0) break; + wF = total - wB; // Weight Foreground + if (wF == 0) break; - sumB += t * histData[t]; + sumB += t * histData[t]; - let mB = sumB / wB; // Mean Background - let mF = (sum - sumB) / wF; // Mean Foreground + let mB = sumB / wB; // Mean Background + let mF = (sum - sumB) / wF; // Mean Foreground - // Calculate Between Class Variance - let varBetween = wB * wF * (mB - mF) * (mB - mF); + // Calculate Between Class Variance + let varBetween = wB * wF * (mB - mF) * (mB - mF); - // Check if new maximum found - if (varBetween > varMax) { - varMax = varBetween; - threshold = t; - } + // Check if new maximum found + if (varBetween > varMax) { + varMax = varBetween; + threshold = t; } + } - return threshold; + return threshold; } \ No newline at end of file diff --git a/src/modules/Threshold/index.js b/src/modules/Threshold/index.js index 11ef888f..71549002 100644 --- a/src/modules/Threshold/index.js +++ b/src/modules/Threshold/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/Tint/Module.js b/src/modules/Tint/Module.js index b29a6ff5..a22c2a53 100644 --- a/src/modules/Tint/Module.js +++ b/src/modules/Tint/Module.js @@ -1,49 +1,49 @@ module.exports = function Tint(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - var color = options.color || defaults.color; - color = color.split(" "); - var factor = options.factor || defaults.factor; + var color = options.color || defaults.color; + color = color.split(' '); + var factor = options.factor || defaults.factor; - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function changePixel(r, g, b, a) { + function changePixel(r, g, b, a) { - r -= (r - color[0]) * factor; - g -= (g - color[1]) * factor; - b -= (b - color[2]) * factor; - return [r, g, b, a] - } + r -= (r - color[0]) * factor; + g -= (g - color[1]) * factor; + b -= (b - color[2]) * factor; + return [r, g, b, a]; + } - function output(image, datauri, mimetype) { + function output(image, datauri, mimetype) { - // This output is accessible by Image Sequencer - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - changePixel: changePixel, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + // This output is accessible by Image Sequencer + step.output = { src: datauri, format: mimetype }; } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + changePixel: changePixel, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/Tint/index.js b/src/modules/Tint/index.js index 11ef888f..71549002 100644 --- a/src/modules/Tint/index.js +++ b/src/modules/Tint/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/WebglDistort/Module.js b/src/modules/WebglDistort/Module.js index 787acfe1..d4308555 100644 --- a/src/modules/WebglDistort/Module.js +++ b/src/modules/WebglDistort/Module.js @@ -3,228 +3,228 @@ */ module.exports = function DoNothing(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - var output; - var fx = require('./glfx') + var output; + var fx = require('./glfx'); - var dataURItoBlob = function dataURItoBlob(dataURI) { - // convert base64/URLEncoded data component to raw binary data held in a string - var byteString; - if (dataURI.split(',')[0].indexOf('base64') >= 0) - byteString = atob(dataURI.split(',')[1]); - else - byteString = unescape(dataURI.split(',')[1]); + var dataURItoBlob = function dataURItoBlob(dataURI) { + // convert base64/URLEncoded data component to raw binary data held in a string + var byteString; + if (dataURI.split(',')[0].indexOf('base64') >= 0) + byteString = atob(dataURI.split(',')[1]); + else + byteString = unescape(dataURI.split(',')[1]); - // separate out the mime component - var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]; + // separate out the mime component + var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]; - // write the bytes of the string to a typed array - var ia = new Uint8Array(byteString.length); - for (var i = 0; i < byteString.length; i++) { - ia[i] = byteString.charCodeAt(i); - } - - return new Blob([ia], { type: mimeString }); + // write the bytes of the string to a typed array + var ia = new Uint8Array(byteString.length); + for (var i = 0; i < byteString.length; i++) { + ia[i] = byteString.charCodeAt(i); } - var canvasToBlobUrl = function canvasToBlobUrl(canvas) { + return new Blob([ia], { type: mimeString }); + }; - var blob = dataURItoBlob(canvas.toDataURL('image/png')); - return window.URL.createObjectURL(blob); + var canvasToBlobUrl = function canvasToBlobUrl(canvas) { + var blob = dataURItoBlob(canvas.toDataURL('image/png')); + return window.URL.createObjectURL(blob); + + }; + + var warpWebGl = function warpWebGl(id, matrix1, matrix2, download) { + + // try to create a WebGL canvas (will fail if WebGL isn't supported) + try { + var canvas = fx.canvas(1500, 1500); + } catch (e) { + alert(e); + return; } - var warpWebGl = function warpWebGl(id, matrix1, matrix2, download) { + // convert the image to a texture + var imageEl = document.getElementById(id); - // try to create a WebGL canvas (will fail if WebGL isn't supported) - try { - var canvas = fx.canvas(1500, 1500); - } catch (e) { - alert(e); - return; - } + var image = new Image(); - // convert the image to a texture - var imageEl = document.getElementById(id); + image.onload = function() { - var image = new Image(); + var texture = canvas.texture(image); - image.onload = function() { + var bbox1 = { + nw: { + x: matrix1[0], + y: matrix1[1] + }, + ne: { + x: matrix1[2], + y: matrix1[3] + }, + se: { + x: matrix1[4], + y: matrix1[5] + }, + sw: { + x: matrix1[6], + y: matrix1[7] + } + }, + bbox2 = { + nw: { + x: matrix2[0], + y: matrix2[1] + }, + ne: { + x: matrix2[2], + y: matrix2[3] + }, + se: { + x: matrix2[4], + y: matrix2[5] + }, + sw: { + x: matrix2[6], + y: matrix2[7] + } + }; - var texture = canvas.texture(image); + var matrix1Xs = [], + matrix1Ys = []; - var bbox1 = { - nw: { - x: matrix1[0], - y: matrix1[1] - }, - ne: { - x: matrix1[2], - y: matrix1[3] - }, - se: { - x: matrix1[4], - y: matrix1[5] - }, - sw: { - x: matrix1[6], - y: matrix1[7] - } - }, - bbox2 = { - nw: { - x: matrix2[0], - y: matrix2[1] - }, - ne: { - x: matrix2[2], - y: matrix2[3] - }, - se: { - x: matrix2[4], - y: matrix2[5] - }, - sw: { - x: matrix2[6], - y: matrix2[7] - } - }; + for (var i = 0; i < matrix1.length; i += 2) { + matrix1Xs.push(matrix1[i]); + } - var matrix1Xs = [], - matrix1Ys = []; + for (var i = 1; i < matrix1.length; i += 2) { + matrix1Ys.push(matrix1[i]); + } - for (var i = 0; i < matrix1.length; i += 2) { - matrix1Xs.push(matrix1[i]) - } + var matrix1northmost = Math.min.apply(null, matrix1Ys); + matrix1southmost = Math.max.apply(null, matrix1Ys); + matrix1westmost = Math.min.apply(null, matrix1Xs); + matrix1eastmost = Math.max.apply(null, matrix1Xs); - for (var i = 1; i < matrix1.length; i += 2) { - matrix1Ys.push(matrix1[i]) - } + var matrix2Xs = [], + matrix2Ys = []; - var matrix1northmost = Math.min.apply(null, matrix1Ys) - matrix1southmost = Math.max.apply(null, matrix1Ys) - matrix1westmost = Math.min.apply(null, matrix1Xs) - matrix1eastmost = Math.max.apply(null, matrix1Xs); + for (var i = 0; i < matrix2.length; i += 2) { + matrix2Xs.push(matrix2[i]); + } - var matrix2Xs = [], - matrix2Ys = []; + for (var i = 1; i < matrix2.length; i += 2) { + matrix2Ys.push(matrix2[i]); + } - for (var i = 0; i < matrix2.length; i += 2) { - matrix2Xs.push(matrix2[i]) - } + var matrix2northmost = Math.min.apply(null, matrix2Ys); + matrix2southmost = Math.max.apply(null, matrix2Ys); + matrix2westmost = Math.min.apply(null, matrix2Xs); + matrix2eastmost = Math.max.apply(null, matrix2Xs); - for (var i = 1; i < matrix2.length; i += 2) { - matrix2Ys.push(matrix2[i]) - } + var offsetX = matrix2westmost - matrix1westmost; + var offsetY = matrix2northmost - matrix1northmost; - var matrix2northmost = Math.min.apply(null, matrix2Ys) - matrix2southmost = Math.max.apply(null, matrix2Ys) - matrix2westmost = Math.min.apply(null, matrix2Xs) - matrix2eastmost = Math.max.apply(null, matrix2Xs); + canvas.draw(texture, + image.width,// * ratio, + image.height// * ratio + ); - var offsetX = matrix2westmost - matrix1westmost; - var offsetY = matrix2northmost - matrix1northmost; - - canvas.draw(texture, - image.width,// * ratio, - image.height// * ratio - ); - - var ratioY = (matrix2southmost - matrix2northmost) + var ratioY = (matrix2southmost - matrix2northmost) / (matrix1southmost - matrix1northmost); - var ratioX = (matrix2eastmost - matrix2westmost) + var ratioX = (matrix2eastmost - matrix2westmost) / (matrix1eastmost - matrix1westmost); - var ratio = Math.max(ratioX, ratioY); + var ratio = Math.max(ratioX, ratioY); - // stretch output matrix x to fix: - for (var i = 0; i < matrix2.length; i += 2) { - matrix2[i] -= offsetX; - matrix2[i] /= ratio; - } + // stretch output matrix x to fix: + for (var i = 0; i < matrix2.length; i += 2) { + matrix2[i] -= offsetX; + matrix2[i] /= ratio; + } - // stretch output matrix y to fix: - for (var i = 1; i < matrix2.length; i += 2) { - matrix2[i] -= offsetY; - matrix2[i] /= ratio; - } + // stretch output matrix y to fix: + for (var i = 1; i < matrix2.length; i += 2) { + matrix2[i] -= offsetY; + matrix2[i] /= ratio; + } - canvas.perspective(matrix1, matrix2).update(); + canvas.perspective(matrix1, matrix2).update(); - // replace the image with the canvas - // image.parentNode.insertBefore(canvas, image); - // image.parentNode.removeChild(image); + // replace the image with the canvas + // image.parentNode.insertBefore(canvas, image); + // image.parentNode.removeChild(image); - var burl = canvasToBlobUrl(canvas); + var burl = canvasToBlobUrl(canvas); - if (download) { + if (download) { - window.open(burl); + window.open(burl); - } else { // replace the image + } else { // replace the image - // keep non-blob version in case we have to fall back: - // image.src = canvas.toDataURL('image/png'); - // window.location = canvas.toDataURL('image/png'); - imageEl.src = burl; + // keep non-blob version in case we have to fall back: + // image.src = canvas.toDataURL('image/png'); + // window.location = canvas.toDataURL('image/png'); + imageEl.src = burl; - } + } - } + }; - image.src = imageEl.src; + image.src = imageEl.src; + }; + + function draw(input, callback) { + + var step = this; + + options.nw = options.nw || defaults.nw; + options.ne = options.ne || defaults.ne; + options.se = options.se || defaults.se; + options.sw = options.sw || defaults.sw; + + var parseDistortCoordinates = require('../../util/parseDistortCoordinates.js'); + var cornerCoordinates = parseDistortCoordinates(options); + + if (!options.inBrowser) { + // this.output = input; + // callback(); + require('../_nomodule/gl-context')(input, callback, step, options); } + else { + var image = document.createElement('img'); + image.onload = () => { + warpWebGl( + 'img', + [0, 0, 1023, 0, 1023, 767, 0, 767], // matrix 1 (before) corner coordinates, NW, NE, SE, SW + // [0, 100, 1023, -50, 1223, 867, 100, 767] // matrix 2 (after) corner coordinates + cornerCoordinates + ); + image.onload = () => { + var canvas = document.createElement('canvas'); + canvas.width = image.naturalWidth; // or 'width' if you want a special/scaled size + canvas.height = image.naturalHeight; // or 'height' if you want a special/scaled size + canvas.getContext('2d').drawImage(image, 0, 0); - function draw(input, callback) { - - var step = this; - - options.nw = options.nw || defaults.nw; - options.ne = options.ne || defaults.ne; - options.se = options.se || defaults.se; - options.sw = options.sw || defaults.sw; - - var parseDistortCoordinates = require('../../util/parseDistortCoordinates.js'); - var cornerCoordinates = parseDistortCoordinates(options) - - if (!options.inBrowser) { - // this.output = input; - // callback(); - require('../_nomodule/gl-context')(input, callback, step, options); - } - else { - var image = document.createElement('img'); - image.onload = () => { - warpWebGl( - 'img', - [0, 0, 1023, 0, 1023, 767, 0, 767], // matrix 1 (before) corner coordinates, NW, NE, SE, SW - // [0, 100, 1023, -50, 1223, 867, 100, 767] // matrix 2 (after) corner coordinates - cornerCoordinates - ); - image.onload = () => { - var canvas = document.createElement('canvas'); - canvas.width = image.naturalWidth; // or 'width' if you want a special/scaled size - canvas.height = image.naturalHeight; // or 'height' if you want a special/scaled size - canvas.getContext('2d').drawImage(image, 0, 0); - - step.output = { src: canvas.toDataURL('image/png'), format: 'png' } - image.remove(); - callback(); - }; - }; - image.src = input.src; - image.id = "img"; - document.body.appendChild(image); - } + step.output = { src: canvas.toDataURL('image/png'), format: 'png' }; + image.remove(); + callback(); + }; + }; + image.src = input.src; + image.id = 'img'; + document.body.appendChild(image); } + } - return { - options: options, - draw: draw, - output: output, - UI: UI - } -} + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/WebglDistort/glfx.js b/src/modules/WebglDistort/glfx.js index d65eb756..8b9f3940 100644 --- a/src/modules/WebglDistort/glfx.js +++ b/src/modules/WebglDistort/glfx.js @@ -6,147 +6,147 @@ * Released under the MIT license */ module.exports = function() { - function q(a, d, c) { return Math.max(a, Math.min(d, c)) } function w(b) { return { _: b, loadContentsOf: function(b) { a = this._.gl; this._.loadContentsOf(b) }, destroy: function() { a = this._.gl; this._.destroy() } } } function A(a) { return w(r.fromElement(a)) } function B(b, d) { - var c = a.UNSIGNED_BYTE; if (a.getExtension("OES_texture_float") && a.getExtension("OES_texture_float_linear")) { var e = new r(100, 100, a.RGBA, a.FLOAT); try { e.drawTo(function() { c = a.FLOAT }) } catch (g) { } e.destroy() } this._.texture && this._.texture.destroy(); - this._.spareTexture && this._.spareTexture.destroy(); this.width = b; this.height = d; this._.texture = new r(b, d, a.RGBA, c); this._.spareTexture = new r(b, d, a.RGBA, c); this._.extraTexture = this._.extraTexture || new r(0, 0, a.RGBA, c); this._.flippedShader = this._.flippedShader || new h(null, "uniform sampler2D texture;varying vec2 texCoord;void main(){gl_FragColor=texture2D(texture,vec2(texCoord.x,1.0-texCoord.y));}"); this._.isInitialized = !0 - } function C(a, d, c) { - this._.isInitialized && - a._.width == this.width && a._.height == this.height || B.call(this, d ? d : a._.width, c ? c : a._.height); a._.use(); this._.texture.drawTo(function() { h.getDefaultShader().drawRect() }); return this - } function D() { this._.texture.use(); this._.flippedShader.drawRect(); return this } function f(a, d, c, e) { (c || this._.texture).use(); this._.spareTexture.drawTo(function() { a.uniforms(d).drawRect() }); this._.spareTexture.swapWith(e || this._.texture) } function E(a) { a.parentNode.insertBefore(this, a); a.parentNode.removeChild(a); return this } - function F() { var b = new r(this._.texture.width, this._.texture.height, a.RGBA, a.UNSIGNED_BYTE); this._.texture.use(); b.drawTo(function() { h.getDefaultShader().drawRect() }); return w(b) } function G() { var b = this._.texture.width, d = this._.texture.height, c = new Uint8Array(4 * b * d); this._.texture.drawTo(function() { a.readPixels(0, 0, b, d, a.RGBA, a.UNSIGNED_BYTE, c) }); return c } function k(b) { return function() { a = this._.gl; return b.apply(this, arguments) } } function x(a, d, c, e, g, l, n, p) { - var m = c - g, h = e - l, f = n - g, k = p - l; g = a - c + g - n; l = - d - e + l - p; var q = m * k - f * h, f = (g * k - f * l) / q, m = (m * l - g * h) / q; return [c - a + f * c, e - d + f * e, f, n - a + m * n, p - d + m * p, m, a, d, 1] - } function y(a) { var d = a[0], c = a[1], e = a[2], g = a[3], l = a[4], n = a[5], p = a[6], m = a[7]; a = a[8]; var f = d * l * a - d * n * m - c * g * a + c * n * p + e * g * m - e * l * p; return [(l * a - n * m) / f, (e * m - c * a) / f, (c * n - e * l) / f, (n * p - g * a) / f, (d * a - e * p) / f, (e * g - d * n) / f, (g * m - l * p) / f, (c * p - d * m) / f, (d * l - c * g) / f] } function z(a) { - var d = a.length; this.xa = []; this.ya = []; this.u = []; this.y2 = []; a.sort(function(a, b) { return a[0] - b[0] }); for (var c = 0; c < d; c++)this.xa.push(a[c][0]), this.ya.push(a[c][1]); - this.u[0] = 0; this.y2[0] = 0; for (c = 1; c < d - 1; ++c) { a = this.xa[c + 1] - this.xa[c - 1]; var e = (this.xa[c] - this.xa[c - 1]) / a, g = e * this.y2[c - 1] + 2; this.y2[c] = (e - 1) / g; this.u[c] = (6 * ((this.ya[c + 1] - this.ya[c]) / (this.xa[c + 1] - this.xa[c]) - (this.ya[c] - this.ya[c - 1]) / (this.xa[c] - this.xa[c - 1])) / a - e * this.u[c - 1]) / g } this.y2[d - 1] = 0; for (c = d - 2; 0 <= c; --c)this.y2[c] = this.y2[c] * this.y2[c + 1] + this.u[c] - } function u(a, d) { - return new h(null, a + "uniform sampler2D texture;uniform vec2 texSize;varying vec2 texCoord;void main(){vec2 coord=texCoord*texSize;" + - d + "gl_FragColor=texture2D(texture,coord/texSize);vec2 clampedCoord=clamp(coord,vec2(0.0),texSize);if(coord!=clampedCoord){gl_FragColor.a*=max(0.0,1.0-length(coord-clampedCoord));}}") - } function H(b, d) { - a.brightnessContrast = a.brightnessContrast || new h(null, "uniform sampler2D texture;uniform float brightness;uniform float contrast;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);color.rgb+=brightness;if(contrast>0.0){color.rgb=(color.rgb-0.5)/(1.0-contrast)+0.5;}else{color.rgb=(color.rgb-0.5)*(1.0+contrast)+0.5;}gl_FragColor=color;}"); - f.call(this, a.brightnessContrast, { brightness: q(-1, b, 1), contrast: q(-1, d, 1) }); return this - } function t(a) { a = new z(a); for (var d = [], c = 0; 256 > c; c++)d.push(q(0, Math.floor(256 * a.interpolate(c / 255)), 255)); return d } function I(b, d, c) { - b = t(b); 1 == arguments.length ? d = c = b : (d = t(d), c = t(c)); for (var e = [], g = 0; 256 > g; g++)e.splice(e.length, 0, b[g], d[g], c[g], 255); this._.extraTexture.initFromBytes(256, 1, e); this._.extraTexture.use(1); a.curves = a.curves || new h(null, "uniform sampler2D texture;uniform sampler2D map;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);color.r=texture2D(map,vec2(color.r)).r;color.g=texture2D(map,vec2(color.g)).g;color.b=texture2D(map,vec2(color.b)).b;gl_FragColor=color;}"); - a.curves.textures({ map: 1 }); f.call(this, a.curves, {}); return this - } function J(b) { - a.denoise = a.denoise || new h(null, "uniform sampler2D texture;uniform float exponent;uniform float strength;uniform vec2 texSize;varying vec2 texCoord;void main(){vec4 center=texture2D(texture,texCoord);vec4 color=vec4(0.0);float total=0.0;for(float x=-4.0;x<=4.0;x+=1.0){for(float y=-4.0;y<=4.0;y+=1.0){vec4 sample=texture2D(texture,texCoord+vec2(x,y)/texSize);float weight=1.0-abs(dot(sample.rgb-center.rgb,vec3(0.25)));weight=pow(weight,exponent);color+=sample*weight;total+=weight;}}gl_FragColor=color/total;}"); - for (var d = 0; 2 > d; d++)f.call(this, a.denoise, { exponent: Math.max(0, b), texSize: [this.width, this.height] }); return this - } function K(b, d) { - a.hueSaturation = a.hueSaturation || new h(null, "uniform sampler2D texture;uniform float hue;uniform float saturation;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float angle=hue*3.14159265;float s=sin(angle),c=cos(angle);vec3 weights=(vec3(2.0*c,-sqrt(3.0)*s-c,sqrt(3.0)*s-c)+1.0)/3.0;float len=length(color.rgb);color.rgb=vec3(dot(color.rgb,weights.xyz),dot(color.rgb,weights.zxy),dot(color.rgb,weights.yzx));float average=(color.r+color.g+color.b)/3.0;if(saturation>0.0){color.rgb+=(average-color.rgb)*(1.0-1.0/(1.001-saturation));}else{color.rgb+=(average-color.rgb)*(-saturation);}gl_FragColor=color;}"); - f.call(this, a.hueSaturation, { hue: q(-1, b, 1), saturation: q(-1, d, 1) }); return this - } function L(b) { - a.noise = a.noise || new h(null, "uniform sampler2D texture;uniform float amount;varying vec2 texCoord;float rand(vec2 co){return fract(sin(dot(co.xy,vec2(12.9898,78.233)))*43758.5453);}void main(){vec4 color=texture2D(texture,texCoord);float diff=(rand(texCoord)-0.5)*amount;color.r+=diff;color.g+=diff;color.b+=diff;gl_FragColor=color;}"); - f.call(this, a.noise, { amount: q(0, b, 1) }); return this - } function M(b) { - a.sepia = a.sepia || new h(null, "uniform sampler2D texture;uniform float amount;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float r=color.r;float g=color.g;float b=color.b;color.r=min(1.0,(r*(1.0-(0.607*amount)))+(g*(0.769*amount))+(b*(0.189*amount)));color.g=min(1.0,(r*0.349*amount)+(g*(1.0-(0.314*amount)))+(b*0.168*amount));color.b=min(1.0,(r*0.272*amount)+(g*0.534*amount)+(b*(1.0-(0.869*amount))));gl_FragColor=color;}"); - f.call(this, a.sepia, { amount: q(0, b, 1) }); return this - } function N(b, d) { - a.unsharpMask = a.unsharpMask || new h(null, "uniform sampler2D blurredTexture;uniform sampler2D originalTexture;uniform float strength;uniform float threshold;varying vec2 texCoord;void main(){vec4 blurred=texture2D(blurredTexture,texCoord);vec4 original=texture2D(originalTexture,texCoord);gl_FragColor=mix(blurred,original,1.0+strength);}"); - this._.extraTexture.ensureFormat(this._.texture); this._.texture.use(); this._.extraTexture.drawTo(function() { h.getDefaultShader().drawRect() }); this._.extraTexture.use(1); this.triangleBlur(b); a.unsharpMask.textures({ originalTexture: 1 }); f.call(this, a.unsharpMask, { strength: d }); this._.extraTexture.unuse(1); return this - } function O(b) { - a.vibrance = a.vibrance || new h(null, "uniform sampler2D texture;uniform float amount;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float average=(color.r+color.g+color.b)/3.0;float mx=max(color.r,max(color.g,color.b));float amt=(mx-average)*(-amount*3.0);color.rgb=mix(color.rgb,vec3(mx),amt);gl_FragColor=color;}"); - f.call(this, a.vibrance, { amount: q(-1, b, 1) }); return this - } function P(b, d) { - a.vignette = a.vignette || new h(null, "uniform sampler2D texture;uniform float size;uniform float amount;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float dist=distance(texCoord,vec2(0.5,0.5));color.rgb*=smoothstep(0.8,size*0.799,dist*(amount+size));gl_FragColor=color;}"); - f.call(this, a.vignette, { size: q(0, b, 1), amount: q(0, d, 1) }); return this - } function Q(b, d, c) { - a.lensBlurPrePass = a.lensBlurPrePass || new h(null, "uniform sampler2D texture;uniform float power;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);color=pow(color,vec4(power));gl_FragColor=vec4(color);}"); var e = "uniform sampler2D texture0;uniform sampler2D texture1;uniform vec2 delta0;uniform vec2 delta1;uniform float power;varying vec2 texCoord;" + - s + "vec4 sample(vec2 delta){float offset=random(vec3(delta,151.7182),0.0);vec4 color=vec4(0.0);float total=0.0;for(float t=0.0;t<=30.0;t++){float percent=(t+offset)/30.0;color+=texture2D(texture0,texCoord+delta*percent);total+=1.0;}return color/total;}"; - a.lensBlur0 = a.lensBlur0 || new h(null, e + "void main(){gl_FragColor=sample(delta0);}"); a.lensBlur1 = a.lensBlur1 || new h(null, e + "void main(){gl_FragColor=(sample(delta0)+sample(delta1))*0.5;}"); a.lensBlur2 = a.lensBlur2 || (new h(null, e + "void main(){vec4 color=(sample(delta0)+2.0*texture2D(texture1,texCoord))/3.0;gl_FragColor=pow(color,vec4(power));}")).textures({ texture1: 1 }); for (var e = - [], g = 0; 3 > g; g++) { var l = c + 2 * g * Math.PI / 3; e.push([b * Math.sin(l) / this.width, b * Math.cos(l) / this.height]) } b = Math.pow(10, q(-1, d, 1)); f.call(this, a.lensBlurPrePass, { power: b }); this._.extraTexture.ensureFormat(this._.texture); f.call(this, a.lensBlur0, { delta0: e[0] }, this._.texture, this._.extraTexture); f.call(this, a.lensBlur1, { delta0: e[1], delta1: e[2] }, this._.extraTexture, this._.extraTexture); f.call(this, a.lensBlur0, { delta0: e[1] }); this._.extraTexture.use(1); f.call(this, a.lensBlur2, { power: 1 / b, delta0: e[2] }); return this + function q(a, d, c) { return Math.max(a, Math.min(d, c)); } function w(b) { return { _: b, loadContentsOf: function(b) { a = this._.gl; this._.loadContentsOf(b); }, destroy: function() { a = this._.gl; this._.destroy(); } }; } function A(a) { return w(r.fromElement(a)); } function B(b, d) { + var c = a.UNSIGNED_BYTE; if (a.getExtension('OES_texture_float') && a.getExtension('OES_texture_float_linear')) { var e = new r(100, 100, a.RGBA, a.FLOAT); try { e.drawTo(function() { c = a.FLOAT; }); } catch (g) { } e.destroy(); } this._.texture && this._.texture.destroy(); + this._.spareTexture && this._.spareTexture.destroy(); this.width = b; this.height = d; this._.texture = new r(b, d, a.RGBA, c); this._.spareTexture = new r(b, d, a.RGBA, c); this._.extraTexture = this._.extraTexture || new r(0, 0, a.RGBA, c); this._.flippedShader = this._.flippedShader || new h(null, 'uniform sampler2D texture;varying vec2 texCoord;void main(){gl_FragColor=texture2D(texture,vec2(texCoord.x,1.0-texCoord.y));}'); this._.isInitialized = !0; + } function C(a, d, c) { + this._.isInitialized && + a._.width == this.width && a._.height == this.height || B.call(this, d ? d : a._.width, c ? c : a._.height); a._.use(); this._.texture.drawTo(function() { h.getDefaultShader().drawRect(); }); return this; + } function D() { this._.texture.use(); this._.flippedShader.drawRect(); return this; } function f(a, d, c, e) { (c || this._.texture).use(); this._.spareTexture.drawTo(function() { a.uniforms(d).drawRect(); }); this._.spareTexture.swapWith(e || this._.texture); } function E(a) { a.parentNode.insertBefore(this, a); a.parentNode.removeChild(a); return this; } + function F() { var b = new r(this._.texture.width, this._.texture.height, a.RGBA, a.UNSIGNED_BYTE); this._.texture.use(); b.drawTo(function() { h.getDefaultShader().drawRect(); }); return w(b); } function G() { var b = this._.texture.width, d = this._.texture.height, c = new Uint8Array(4 * b * d); this._.texture.drawTo(function() { a.readPixels(0, 0, b, d, a.RGBA, a.UNSIGNED_BYTE, c); }); return c; } function k(b) { return function() { a = this._.gl; return b.apply(this, arguments); }; } function x(a, d, c, e, g, l, n, p) { + var m = c - g, h = e - l, f = n - g, k = p - l; g = a - c + g - n; l = + d - e + l - p; var q = m * k - f * h, f = (g * k - f * l) / q, m = (m * l - g * h) / q; return [c - a + f * c, e - d + f * e, f, n - a + m * n, p - d + m * p, m, a, d, 1]; + } function y(a) { var d = a[0], c = a[1], e = a[2], g = a[3], l = a[4], n = a[5], p = a[6], m = a[7]; a = a[8]; var f = d * l * a - d * n * m - c * g * a + c * n * p + e * g * m - e * l * p; return [(l * a - n * m) / f, (e * m - c * a) / f, (c * n - e * l) / f, (n * p - g * a) / f, (d * a - e * p) / f, (e * g - d * n) / f, (g * m - l * p) / f, (c * p - d * m) / f, (d * l - c * g) / f]; } function z(a) { + var d = a.length; this.xa = []; this.ya = []; this.u = []; this.y2 = []; a.sort(function(a, b) { return a[0] - b[0]; }); for (var c = 0; c < d; c++)this.xa.push(a[c][0]), this.ya.push(a[c][1]); + this.u[0] = 0; this.y2[0] = 0; for (c = 1; c < d - 1; ++c) { a = this.xa[c + 1] - this.xa[c - 1]; var e = (this.xa[c] - this.xa[c - 1]) / a, g = e * this.y2[c - 1] + 2; this.y2[c] = (e - 1) / g; this.u[c] = (6 * ((this.ya[c + 1] - this.ya[c]) / (this.xa[c + 1] - this.xa[c]) - (this.ya[c] - this.ya[c - 1]) / (this.xa[c] - this.xa[c - 1])) / a - e * this.u[c - 1]) / g; } this.y2[d - 1] = 0; for (c = d - 2; 0 <= c; --c)this.y2[c] = this.y2[c] * this.y2[c + 1] + this.u[c]; + } function u(a, d) { + return new h(null, a + 'uniform sampler2D texture;uniform vec2 texSize;varying vec2 texCoord;void main(){vec2 coord=texCoord*texSize;' + + d + 'gl_FragColor=texture2D(texture,coord/texSize);vec2 clampedCoord=clamp(coord,vec2(0.0),texSize);if(coord!=clampedCoord){gl_FragColor.a*=max(0.0,1.0-length(coord-clampedCoord));}}'); + } function H(b, d) { + a.brightnessContrast = a.brightnessContrast || new h(null, 'uniform sampler2D texture;uniform float brightness;uniform float contrast;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);color.rgb+=brightness;if(contrast>0.0){color.rgb=(color.rgb-0.5)/(1.0-contrast)+0.5;}else{color.rgb=(color.rgb-0.5)*(1.0+contrast)+0.5;}gl_FragColor=color;}'); + f.call(this, a.brightnessContrast, { brightness: q(-1, b, 1), contrast: q(-1, d, 1) }); return this; + } function t(a) { a = new z(a); for (var d = [], c = 0; 256 > c; c++)d.push(q(0, Math.floor(256 * a.interpolate(c / 255)), 255)); return d; } function I(b, d, c) { + b = t(b); 1 == arguments.length ? d = c = b : (d = t(d), c = t(c)); for (var e = [], g = 0; 256 > g; g++)e.splice(e.length, 0, b[g], d[g], c[g], 255); this._.extraTexture.initFromBytes(256, 1, e); this._.extraTexture.use(1); a.curves = a.curves || new h(null, 'uniform sampler2D texture;uniform sampler2D map;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);color.r=texture2D(map,vec2(color.r)).r;color.g=texture2D(map,vec2(color.g)).g;color.b=texture2D(map,vec2(color.b)).b;gl_FragColor=color;}'); + a.curves.textures({ map: 1 }); f.call(this, a.curves, {}); return this; + } function J(b) { + a.denoise = a.denoise || new h(null, 'uniform sampler2D texture;uniform float exponent;uniform float strength;uniform vec2 texSize;varying vec2 texCoord;void main(){vec4 center=texture2D(texture,texCoord);vec4 color=vec4(0.0);float total=0.0;for(float x=-4.0;x<=4.0;x+=1.0){for(float y=-4.0;y<=4.0;y+=1.0){vec4 sample=texture2D(texture,texCoord+vec2(x,y)/texSize);float weight=1.0-abs(dot(sample.rgb-center.rgb,vec3(0.25)));weight=pow(weight,exponent);color+=sample*weight;total+=weight;}}gl_FragColor=color/total;}'); + for (var d = 0; 2 > d; d++)f.call(this, a.denoise, { exponent: Math.max(0, b), texSize: [this.width, this.height] }); return this; + } function K(b, d) { + a.hueSaturation = a.hueSaturation || new h(null, 'uniform sampler2D texture;uniform float hue;uniform float saturation;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float angle=hue*3.14159265;float s=sin(angle),c=cos(angle);vec3 weights=(vec3(2.0*c,-sqrt(3.0)*s-c,sqrt(3.0)*s-c)+1.0)/3.0;float len=length(color.rgb);color.rgb=vec3(dot(color.rgb,weights.xyz),dot(color.rgb,weights.zxy),dot(color.rgb,weights.yzx));float average=(color.r+color.g+color.b)/3.0;if(saturation>0.0){color.rgb+=(average-color.rgb)*(1.0-1.0/(1.001-saturation));}else{color.rgb+=(average-color.rgb)*(-saturation);}gl_FragColor=color;}'); + f.call(this, a.hueSaturation, { hue: q(-1, b, 1), saturation: q(-1, d, 1) }); return this; + } function L(b) { + a.noise = a.noise || new h(null, 'uniform sampler2D texture;uniform float amount;varying vec2 texCoord;float rand(vec2 co){return fract(sin(dot(co.xy,vec2(12.9898,78.233)))*43758.5453);}void main(){vec4 color=texture2D(texture,texCoord);float diff=(rand(texCoord)-0.5)*amount;color.r+=diff;color.g+=diff;color.b+=diff;gl_FragColor=color;}'); + f.call(this, a.noise, { amount: q(0, b, 1) }); return this; + } function M(b) { + a.sepia = a.sepia || new h(null, 'uniform sampler2D texture;uniform float amount;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float r=color.r;float g=color.g;float b=color.b;color.r=min(1.0,(r*(1.0-(0.607*amount)))+(g*(0.769*amount))+(b*(0.189*amount)));color.g=min(1.0,(r*0.349*amount)+(g*(1.0-(0.314*amount)))+(b*0.168*amount));color.b=min(1.0,(r*0.272*amount)+(g*0.534*amount)+(b*(1.0-(0.869*amount))));gl_FragColor=color;}'); + f.call(this, a.sepia, { amount: q(0, b, 1) }); return this; + } function N(b, d) { + a.unsharpMask = a.unsharpMask || new h(null, 'uniform sampler2D blurredTexture;uniform sampler2D originalTexture;uniform float strength;uniform float threshold;varying vec2 texCoord;void main(){vec4 blurred=texture2D(blurredTexture,texCoord);vec4 original=texture2D(originalTexture,texCoord);gl_FragColor=mix(blurred,original,1.0+strength);}'); + this._.extraTexture.ensureFormat(this._.texture); this._.texture.use(); this._.extraTexture.drawTo(function() { h.getDefaultShader().drawRect(); }); this._.extraTexture.use(1); this.triangleBlur(b); a.unsharpMask.textures({ originalTexture: 1 }); f.call(this, a.unsharpMask, { strength: d }); this._.extraTexture.unuse(1); return this; + } function O(b) { + a.vibrance = a.vibrance || new h(null, 'uniform sampler2D texture;uniform float amount;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float average=(color.r+color.g+color.b)/3.0;float mx=max(color.r,max(color.g,color.b));float amt=(mx-average)*(-amount*3.0);color.rgb=mix(color.rgb,vec3(mx),amt);gl_FragColor=color;}'); + f.call(this, a.vibrance, { amount: q(-1, b, 1) }); return this; + } function P(b, d) { + a.vignette = a.vignette || new h(null, 'uniform sampler2D texture;uniform float size;uniform float amount;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);float dist=distance(texCoord,vec2(0.5,0.5));color.rgb*=smoothstep(0.8,size*0.799,dist*(amount+size));gl_FragColor=color;}'); + f.call(this, a.vignette, { size: q(0, b, 1), amount: q(0, d, 1) }); return this; + } function Q(b, d, c) { + a.lensBlurPrePass = a.lensBlurPrePass || new h(null, 'uniform sampler2D texture;uniform float power;varying vec2 texCoord;void main(){vec4 color=texture2D(texture,texCoord);color=pow(color,vec4(power));gl_FragColor=vec4(color);}'); var e = 'uniform sampler2D texture0;uniform sampler2D texture1;uniform vec2 delta0;uniform vec2 delta1;uniform float power;varying vec2 texCoord;' + + s + 'vec4 sample(vec2 delta){float offset=random(vec3(delta,151.7182),0.0);vec4 color=vec4(0.0);float total=0.0;for(float t=0.0;t<=30.0;t++){float percent=(t+offset)/30.0;color+=texture2D(texture0,texCoord+delta*percent);total+=1.0;}return color/total;}'; + a.lensBlur0 = a.lensBlur0 || new h(null, e + 'void main(){gl_FragColor=sample(delta0);}'); a.lensBlur1 = a.lensBlur1 || new h(null, e + 'void main(){gl_FragColor=(sample(delta0)+sample(delta1))*0.5;}'); a.lensBlur2 = a.lensBlur2 || (new h(null, e + 'void main(){vec4 color=(sample(delta0)+2.0*texture2D(texture1,texCoord))/3.0;gl_FragColor=pow(color,vec4(power));}')).textures({ texture1: 1 }); for (var e = + [], g = 0; 3 > g; g++) { var l = c + 2 * g * Math.PI / 3; e.push([b * Math.sin(l) / this.width, b * Math.cos(l) / this.height]); } b = Math.pow(10, q(-1, d, 1)); f.call(this, a.lensBlurPrePass, { power: b }); this._.extraTexture.ensureFormat(this._.texture); f.call(this, a.lensBlur0, { delta0: e[0] }, this._.texture, this._.extraTexture); f.call(this, a.lensBlur1, { delta0: e[1], delta1: e[2] }, this._.extraTexture, this._.extraTexture); f.call(this, a.lensBlur0, { delta0: e[1] }); this._.extraTexture.use(1); f.call(this, a.lensBlur2, { power: 1 / b, delta0: e[2] }); return this; + } + function R(b, d, c, e, g, l) { + a.tiltShift = a.tiltShift || new h(null, 'uniform sampler2D texture;uniform float blurRadius;uniform float gradientRadius;uniform vec2 start;uniform vec2 end;uniform vec2 delta;uniform vec2 texSize;varying vec2 texCoord;' + s + 'void main(){vec4 color=vec4(0.0);float total=0.0;float offset=random(vec3(12.9898,78.233,151.7182),0.0);vec2 normal=normalize(vec2(start.y-end.y,end.x-start.x));float radius=smoothstep(0.0,1.0,abs(dot(texCoord*texSize-start,normal))/gradientRadius)*blurRadius;for(float t=-30.0;t<=30.0;t++){float percent=(t+offset-0.5)/30.0;float weight=1.0-abs(percent);vec4 sample=texture2D(texture,texCoord+delta/texSize*percent*radius);sample.rgb*=sample.a;color+=sample*weight;total+=weight;}gl_FragColor=color/total;gl_FragColor.rgb/=gl_FragColor.a+0.00001;}'); + var n = c - b, p = e - d, m = Math.sqrt(n * n + p * p); f.call(this, a.tiltShift, { blurRadius: g, gradientRadius: l, start: [b, d], end: [c, e], delta: [n / m, p / m], texSize: [this.width, this.height] }); f.call(this, a.tiltShift, { blurRadius: g, gradientRadius: l, start: [b, d], end: [c, e], delta: [-p / m, n / m], texSize: [this.width, this.height] }); return this; + } function S(b) { + a.triangleBlur = a.triangleBlur || new h(null, 'uniform sampler2D texture;uniform vec2 delta;varying vec2 texCoord;' + s + 'void main(){vec4 color=vec4(0.0);float total=0.0;float offset=random(vec3(12.9898,78.233,151.7182),0.0);for(float t=-30.0;t<=30.0;t++){float percent=(t+offset-0.5)/30.0;float weight=1.0-abs(percent);vec4 sample=texture2D(texture,texCoord+delta*percent);sample.rgb*=sample.a;color+=sample*weight;total+=weight;}gl_FragColor=color/total;gl_FragColor.rgb/=gl_FragColor.a+0.00001;}'); + f.call(this, a.triangleBlur, { delta: [b / this.width, 0] }); f.call(this, a.triangleBlur, { delta: [0, b / this.height] }); return this; + } function T(b, d, c) { + a.zoomBlur = a.zoomBlur || new h(null, 'uniform sampler2D texture;uniform vec2 center;uniform float strength;uniform vec2 texSize;varying vec2 texCoord;' + s + 'void main(){vec4 color=vec4(0.0);float total=0.0;vec2 toCenter=center-texCoord*texSize;float offset=random(vec3(12.9898,78.233,151.7182),0.0);for(float t=0.0;t<=40.0;t++){float percent=(t+offset)/40.0;float weight=4.0*(percent-percent*percent);vec4 sample=texture2D(texture,texCoord+toCenter*percent*strength/texSize);sample.rgb*=sample.a;color+=sample*weight;total+=weight;}gl_FragColor=color/total;gl_FragColor.rgb/=gl_FragColor.a+0.00001;}'); + f.call(this, a.zoomBlur, { center: [b, d], strength: c, texSize: [this.width, this.height] }); return this; + } function U(b, d, c, e) { + a.colorHalftone = a.colorHalftone || new h(null, 'uniform sampler2D texture;uniform vec2 center;uniform float angle;uniform float scale;uniform vec2 texSize;varying vec2 texCoord;float pattern(float angle){float s=sin(angle),c=cos(angle);vec2 tex=texCoord*texSize-center;vec2 point=vec2(c*tex.x-s*tex.y,s*tex.x+c*tex.y)*scale;return(sin(point.x)*sin(point.y))*4.0;}void main(){vec4 color=texture2D(texture,texCoord);vec3 cmy=1.0-color.rgb;float k=min(cmy.x,min(cmy.y,cmy.z));cmy=(cmy-k)/(1.0-k);cmy=clamp(cmy*10.0-3.0+vec3(pattern(angle+0.26179),pattern(angle+1.30899),pattern(angle)),0.0,1.0);k=clamp(k*10.0-5.0+pattern(angle+0.78539),0.0,1.0);gl_FragColor=vec4(1.0-cmy-k,color.a);}'); + f.call(this, a.colorHalftone, { center: [b, d], angle: c, scale: Math.PI / e, texSize: [this.width, this.height] }); return this; + } function V(b, d, c, e) { + a.dotScreen = a.dotScreen || new h(null, 'uniform sampler2D texture;uniform vec2 center;uniform float angle;uniform float scale;uniform vec2 texSize;varying vec2 texCoord;float pattern(){float s=sin(angle),c=cos(angle);vec2 tex=texCoord*texSize-center;vec2 point=vec2(c*tex.x-s*tex.y,s*tex.x+c*tex.y)*scale;return(sin(point.x)*sin(point.y))*4.0;}void main(){vec4 color=texture2D(texture,texCoord);float average=(color.r+color.g+color.b)/3.0;gl_FragColor=vec4(vec3(average*10.0-5.0+pattern()),color.a);}'); + f.call(this, a.dotScreen, { center: [b, d], angle: c, scale: Math.PI / e, texSize: [this.width, this.height] }); return this; + } function W(b) { + a.edgeWork1 = a.edgeWork1 || new h(null, 'uniform sampler2D texture;uniform vec2 delta;varying vec2 texCoord;' + s + 'void main(){vec2 color=vec2(0.0);vec2 total=vec2(0.0);float offset=random(vec3(12.9898,78.233,151.7182),0.0);for(float t=-30.0;t<=30.0;t++){float percent=(t+offset-0.5)/30.0;float weight=1.0-abs(percent);vec3 sample=texture2D(texture,texCoord+delta*percent).rgb;float average=(sample.r+sample.g+sample.b)/3.0;color.x+=average*weight;total.x+=weight;if(abs(t)<15.0){weight=weight*2.0-1.0;color.y+=average*weight;total.y+=weight;}}gl_FragColor=vec4(color/total,0.0,1.0);}'); + a.edgeWork2 = a.edgeWork2 || new h(null, 'uniform sampler2D texture;uniform vec2 delta;varying vec2 texCoord;' + s + 'void main(){vec2 color=vec2(0.0);vec2 total=vec2(0.0);float offset=random(vec3(12.9898,78.233,151.7182),0.0);for(float t=-30.0;t<=30.0;t++){float percent=(t+offset-0.5)/30.0;float weight=1.0-abs(percent);vec2 sample=texture2D(texture,texCoord+delta*percent).xy;color.x+=sample.x*weight;total.x+=weight;if(abs(t)<15.0){weight=weight*2.0-1.0;color.y+=sample.y*weight;total.y+=weight;}}float c=clamp(10000.0*(color.y/total.y-color.x/total.x)+0.5,0.0,1.0);gl_FragColor=vec4(c,c,c,1.0);}'); + f.call(this, a.edgeWork1, { delta: [b / this.width, 0] }); f.call(this, a.edgeWork2, { delta: [0, b / this.height] }); return this; + } function X(b, d, c) { + a.hexagonalPixelate = a.hexagonalPixelate || new h(null, 'uniform sampler2D texture;uniform vec2 center;uniform float scale;uniform vec2 texSize;varying vec2 texCoord;void main(){vec2 tex=(texCoord*texSize-center)/scale;tex.y/=0.866025404;tex.x-=tex.y*0.5;vec2 a;if(tex.x+tex.y-floor(tex.x)-floor(tex.y)<1.0)a=vec2(floor(tex.x),floor(tex.y));else a=vec2(ceil(tex.x),ceil(tex.y));vec2 b=vec2(ceil(tex.x),floor(tex.y));vec2 c=vec2(floor(tex.x),ceil(tex.y));vec3 TEX=vec3(tex.x,tex.y,1.0-tex.x-tex.y);vec3 A=vec3(a.x,a.y,1.0-a.x-a.y);vec3 B=vec3(b.x,b.y,1.0-b.x-b.y);vec3 C=vec3(c.x,c.y,1.0-c.x-c.y);float alen=length(TEX-A);float blen=length(TEX-B);float clen=length(TEX-C);vec2 choice;if(alen0.0){coord*=mix(1.0,smoothstep(0.0,radius/distance,percent),strength*0.75);}else{coord*=mix(1.0,pow(percent,1.0+strength*0.75)*radius/distance,1.0-percent);}}coord+=center;'); + f.call(this, a.bulgePinch, { radius: c, strength: q(-1, e, 1), center: [b, d], texSize: [this.width, this.height] }); return this; + } function $(b, d, c) { + a.matrixWarp = a.matrixWarp || u('uniform mat3 matrix;uniform bool useTextureSpace;', 'if(useTextureSpace)coord=coord/texSize*2.0-1.0;vec3 warp=matrix*vec3(coord,1.0);coord=warp.xy/warp.z;if(useTextureSpace)coord=(coord*0.5+0.5)*texSize;'); b = Array.prototype.concat.apply([], b); if (4 == b.length) b = + [b[0], b[1], 0, b[2], b[3], 0, 0, 0, 1]; else if (9 != b.length) throw 'can only warp with 2x2 or 3x3 matrix'; f.call(this, a.matrixWarp, { matrix: d ? y(b) : b, texSize: [this.width, this.height], useTextureSpace: c | 0 }); return this; + } function aa(a, d) { + var c = x.apply(null, d), e = x.apply(null, a), c = y(c); return this.matrixWarp([c[0] * e[0] + c[1] * e[3] + c[2] * e[6], c[0] * e[1] + c[1] * e[4] + c[2] * e[7], c[0] * e[2] + c[1] * e[5] + c[2] * e[8], c[3] * e[0] + c[4] * e[3] + c[5] * e[6], c[3] * e[1] + c[4] * e[4] + c[5] * e[7], c[3] * e[2] + c[4] * e[5] + c[5] * e[8], c[6] * e[0] + c[7] * e[3] + c[8] * e[6], + c[6] * e[1] + c[7] * e[4] + c[8] * e[7], c[6] * e[2] + c[7] * e[5] + c[8] * e[8]]); + } function ba(b, d, c, e) { + a.swirl = a.swirl || u('uniform float radius;uniform float angle;uniform vec2 center;', 'coord-=center;float distance=length(coord);if(distance0.0){coord*=mix(1.0,smoothstep(0.0,radius/distance,percent),strength*0.75);}else{coord*=mix(1.0,pow(percent,1.0+strength*0.75)*radius/distance,1.0-percent);}}coord+=center;"); - f.call(this, a.bulgePinch, { radius: c, strength: q(-1, e, 1), center: [b, d], texSize: [this.width, this.height] }); return this - } function $(b, d, c) { - a.matrixWarp = a.matrixWarp || u("uniform mat3 matrix;uniform bool useTextureSpace;", "if(useTextureSpace)coord=coord/texSize*2.0-1.0;vec3 warp=matrix*vec3(coord,1.0);coord=warp.xy/warp.z;if(useTextureSpace)coord=(coord*0.5+0.5)*texSize;"); b = Array.prototype.concat.apply([], b); if (4 == b.length) b = - [b[0], b[1], 0, b[2], b[3], 0, 0, 0, 1]; else if (9 != b.length) throw "can only warp with 2x2 or 3x3 matrix"; f.call(this, a.matrixWarp, { matrix: d ? y(b) : b, texSize: [this.width, this.height], useTextureSpace: c | 0 }); return this - } function aa(a, d) { - var c = x.apply(null, d), e = x.apply(null, a), c = y(c); return this.matrixWarp([c[0] * e[0] + c[1] * e[3] + c[2] * e[6], c[0] * e[1] + c[1] * e[4] + c[2] * e[7], c[0] * e[2] + c[1] * e[5] + c[2] * e[8], c[3] * e[0] + c[4] * e[3] + c[5] * e[6], c[3] * e[1] + c[4] * e[4] + c[5] * e[7], c[3] * e[2] + c[4] * e[5] + c[5] * e[8], c[6] * e[0] + c[7] * e[3] + c[8] * e[6], - c[6] * e[1] + c[7] * e[4] + c[8] * e[7], c[6] * e[2] + c[7] * e[5] + c[8] * e[8]]) - } function ba(b, d, c, e) { - a.swirl = a.swirl || u("uniform float radius;uniform float angle;uniform vec2 center;", "coord-=center;float distance=length(coord);if(distance> 1; this.xa[e] > a ? c = e : d = e } var e = this.xa[c] - - this.xa[d], g = (this.xa[c] - a) / e; a = (a - this.xa[d]) / e; return g * this.ya[d] + a * this.ya[c] + ((g * g * g - g) * this.y2[d] + (a * a * a - a) * this.y2[c]) * e * e / 6 - }; var r = function() { - function b(b, c, d, f) { - this.gl = a; this.id = a.createTexture(); this.width = b; this.height = c; this.format = d; this.type = f; a.bindTexture(a.TEXTURE_2D, this.id); a.texParameteri(a.TEXTURE_2D, a.TEXTURE_MAG_FILTER, a.LINEAR); a.texParameteri(a.TEXTURE_2D, a.TEXTURE_MIN_FILTER, a.LINEAR); a.texParameteri(a.TEXTURE_2D, a.TEXTURE_WRAP_S, a.CLAMP_TO_EDGE); a.texParameteri(a.TEXTURE_2D, - a.TEXTURE_WRAP_T, a.CLAMP_TO_EDGE); b && c && a.texImage2D(a.TEXTURE_2D, 0, this.format, b, c, 0, this.format, this.type, null) - } function d(a) { null == c && (c = document.createElement("canvas")); c.width = a.width; c.height = a.height; a = c.getContext("2d"); a.clearRect(0, 0, c.width, c.height); return a } b.fromElement = function(c) { var d = new b(0, 0, a.RGBA, a.UNSIGNED_BYTE); d.loadContentsOf(c); return d }; b.prototype.loadContentsOf = function(b) { - this.width = b.width || b.videoWidth; this.height = b.height || b.videoHeight; a.bindTexture(a.TEXTURE_2D, - this.id); a.texImage2D(a.TEXTURE_2D, 0, this.format, this.format, this.type, b) - }; b.prototype.initFromBytes = function(b, c, d) { this.width = b; this.height = c; this.format = a.RGBA; this.type = a.UNSIGNED_BYTE; a.bindTexture(a.TEXTURE_2D, this.id); a.texImage2D(a.TEXTURE_2D, 0, a.RGBA, b, c, 0, a.RGBA, this.type, new Uint8Array(d)) }; b.prototype.destroy = function() { a.deleteTexture(this.id); this.id = null }; b.prototype.use = function(b) { a.activeTexture(a.TEXTURE0 + (b || 0)); a.bindTexture(a.TEXTURE_2D, this.id) }; b.prototype.unuse = function(b) { - a.activeTexture(a.TEXTURE0 + - (b || 0)); a.bindTexture(a.TEXTURE_2D, null) - }; b.prototype.ensureFormat = function(b, c, d, f) { if (1 == arguments.length) { var h = arguments[0]; b = h.width; c = h.height; d = h.format; f = h.type } if (b != this.width || c != this.height || d != this.format || f != this.type) this.width = b, this.height = c, this.format = d, this.type = f, a.bindTexture(a.TEXTURE_2D, this.id), a.texImage2D(a.TEXTURE_2D, 0, this.format, b, c, 0, this.format, this.type, null) }; b.prototype.drawTo = function(b) { - a.framebuffer = a.framebuffer || a.createFramebuffer(); a.bindFramebuffer(a.FRAMEBUFFER, - a.framebuffer); a.framebufferTexture2D(a.FRAMEBUFFER, a.COLOR_ATTACHMENT0, a.TEXTURE_2D, this.id, 0); if (a.checkFramebufferStatus(a.FRAMEBUFFER) !== a.FRAMEBUFFER_COMPLETE) throw Error("incomplete framebuffer"); a.viewport(0, 0, this.width, this.height); b(); a.bindFramebuffer(a.FRAMEBUFFER, null) - }; var c = null; b.prototype.fillUsingCanvas = function(b) { b(d(this)); this.format = a.RGBA; this.type = a.UNSIGNED_BYTE; a.bindTexture(a.TEXTURE_2D, this.id); a.texImage2D(a.TEXTURE_2D, 0, a.RGBA, a.RGBA, a.UNSIGNED_BYTE, c); return this }; - b.prototype.toImage = function(b) { this.use(); h.getDefaultShader().drawRect(); var f = 4 * this.width * this.height, k = new Uint8Array(f), n = d(this), p = n.createImageData(this.width, this.height); a.readPixels(0, 0, this.width, this.height, a.RGBA, a.UNSIGNED_BYTE, k); for (var m = 0; m < f; m++)p.data[m] = k[m]; n.putImageData(p, 0, 0); b.src = c.toDataURL() }; b.prototype.swapWith = function(a) { - var b; b = a.id; a.id = this.id; this.id = b; b = a.width; a.width = this.width; this.width = b; b = a.height; a.height = this.height; this.height = b; b = a.format; a.format = - this.format; this.format = b - }; return b - }(), s = "float random(vec3 scale,float seed){return fract(sin(dot(gl_FragCoord.xyz+seed,scale))*43758.5453+seed);}"; return v + } return this; + }; d.prototype.textures = function(b) { a.useProgram(this.program); for (var c in b) b.hasOwnProperty(c) && a.uniform1i(a.getUniformLocation(this.program, c), b[c]); return this; }; d.prototype.drawRect = function(b, c, e, d) { + var f = a.getParameter(a.VIEWPORT); c = void 0 !== c ? (c - f[1]) / f[3] : 0; b = void 0 !== b ? (b - f[0]) / f[2] : 0; e = void 0 !== e ? (e - f[0]) / f[2] : 1; d = void 0 !== d ? (d - f[1]) / f[3] : 1; null == a.vertexBuffer && (a.vertexBuffer = a.createBuffer()); a.bindBuffer(a.ARRAY_BUFFER, a.vertexBuffer); a.bufferData(a.ARRAY_BUFFER, new Float32Array([b, + c, b, d, e, c, e, d]), a.STATIC_DRAW); null == a.texCoordBuffer && (a.texCoordBuffer = a.createBuffer(), a.bindBuffer(a.ARRAY_BUFFER, a.texCoordBuffer), a.bufferData(a.ARRAY_BUFFER, new Float32Array([0, 0, 0, 1, 1, 0, 1, 1]), a.STATIC_DRAW)); null == this.vertexAttribute && (this.vertexAttribute = a.getAttribLocation(this.program, 'vertex'), a.enableVertexAttribArray(this.vertexAttribute)); null == this.texCoordAttribute && (this.texCoordAttribute = a.getAttribLocation(this.program, '_texCoord'), a.enableVertexAttribArray(this.texCoordAttribute)); + a.useProgram(this.program); a.bindBuffer(a.ARRAY_BUFFER, a.vertexBuffer); a.vertexAttribPointer(this.vertexAttribute, 2, a.FLOAT, !1, 0, 0); a.bindBuffer(a.ARRAY_BUFFER, a.texCoordBuffer); a.vertexAttribPointer(this.texCoordAttribute, 2, a.FLOAT, !1, 0, 0); a.drawArrays(a.TRIANGLE_STRIP, 0, 4); + }; d.getDefaultShader = function() { a.defaultShader = a.defaultShader || new d; return a.defaultShader; }; return d; + }(); z.prototype.interpolate = function(a) { + for (var d = 0, c = this.ya.length - 1; 1 < c - d;) { var e = c + d >> 1; this.xa[e] > a ? c = e : d = e; } var e = this.xa[c] - + this.xa[d], g = (this.xa[c] - a) / e; a = (a - this.xa[d]) / e; return g * this.ya[d] + a * this.ya[c] + ((g * g * g - g) * this.y2[d] + (a * a * a - a) * this.y2[c]) * e * e / 6; + }; var r = function() { + function b(b, c, d, f) { + this.gl = a; this.id = a.createTexture(); this.width = b; this.height = c; this.format = d; this.type = f; a.bindTexture(a.TEXTURE_2D, this.id); a.texParameteri(a.TEXTURE_2D, a.TEXTURE_MAG_FILTER, a.LINEAR); a.texParameteri(a.TEXTURE_2D, a.TEXTURE_MIN_FILTER, a.LINEAR); a.texParameteri(a.TEXTURE_2D, a.TEXTURE_WRAP_S, a.CLAMP_TO_EDGE); a.texParameteri(a.TEXTURE_2D, + a.TEXTURE_WRAP_T, a.CLAMP_TO_EDGE); b && c && a.texImage2D(a.TEXTURE_2D, 0, this.format, b, c, 0, this.format, this.type, null); + } function d(a) { null == c && (c = document.createElement('canvas')); c.width = a.width; c.height = a.height; a = c.getContext('2d'); a.clearRect(0, 0, c.width, c.height); return a; } b.fromElement = function(c) { var d = new b(0, 0, a.RGBA, a.UNSIGNED_BYTE); d.loadContentsOf(c); return d; }; b.prototype.loadContentsOf = function(b) { + this.width = b.width || b.videoWidth; this.height = b.height || b.videoHeight; a.bindTexture(a.TEXTURE_2D, + this.id); a.texImage2D(a.TEXTURE_2D, 0, this.format, this.format, this.type, b); + }; b.prototype.initFromBytes = function(b, c, d) { this.width = b; this.height = c; this.format = a.RGBA; this.type = a.UNSIGNED_BYTE; a.bindTexture(a.TEXTURE_2D, this.id); a.texImage2D(a.TEXTURE_2D, 0, a.RGBA, b, c, 0, a.RGBA, this.type, new Uint8Array(d)); }; b.prototype.destroy = function() { a.deleteTexture(this.id); this.id = null; }; b.prototype.use = function(b) { a.activeTexture(a.TEXTURE0 + (b || 0)); a.bindTexture(a.TEXTURE_2D, this.id); }; b.prototype.unuse = function(b) { + a.activeTexture(a.TEXTURE0 + + (b || 0)); a.bindTexture(a.TEXTURE_2D, null); + }; b.prototype.ensureFormat = function(b, c, d, f) { if (1 == arguments.length) { var h = arguments[0]; b = h.width; c = h.height; d = h.format; f = h.type; } if (b != this.width || c != this.height || d != this.format || f != this.type) this.width = b, this.height = c, this.format = d, this.type = f, a.bindTexture(a.TEXTURE_2D, this.id), a.texImage2D(a.TEXTURE_2D, 0, this.format, b, c, 0, this.format, this.type, null); }; b.prototype.drawTo = function(b) { + a.framebuffer = a.framebuffer || a.createFramebuffer(); a.bindFramebuffer(a.FRAMEBUFFER, + a.framebuffer); a.framebufferTexture2D(a.FRAMEBUFFER, a.COLOR_ATTACHMENT0, a.TEXTURE_2D, this.id, 0); if (a.checkFramebufferStatus(a.FRAMEBUFFER) !== a.FRAMEBUFFER_COMPLETE) throw Error('incomplete framebuffer'); a.viewport(0, 0, this.width, this.height); b(); a.bindFramebuffer(a.FRAMEBUFFER, null); + }; var c = null; b.prototype.fillUsingCanvas = function(b) { b(d(this)); this.format = a.RGBA; this.type = a.UNSIGNED_BYTE; a.bindTexture(a.TEXTURE_2D, this.id); a.texImage2D(a.TEXTURE_2D, 0, a.RGBA, a.RGBA, a.UNSIGNED_BYTE, c); return this; }; + b.prototype.toImage = function(b) { this.use(); h.getDefaultShader().drawRect(); var f = 4 * this.width * this.height, k = new Uint8Array(f), n = d(this), p = n.createImageData(this.width, this.height); a.readPixels(0, 0, this.width, this.height, a.RGBA, a.UNSIGNED_BYTE, k); for (var m = 0; m < f; m++)p.data[m] = k[m]; n.putImageData(p, 0, 0); b.src = c.toDataURL(); }; b.prototype.swapWith = function(a) { + var b; b = a.id; a.id = this.id; this.id = b; b = a.width; a.width = this.width; this.width = b; b = a.height; a.height = this.height; this.height = b; b = a.format; a.format = + this.format; this.format = b; + }; return b; + }(), s = 'float random(vec3 scale,float seed){return fract(sin(dot(gl_FragCoord.xyz+seed,scale))*43758.5453+seed);}'; return v; }(); \ No newline at end of file diff --git a/src/modules/WebglDistort/index.js b/src/modules/WebglDistort/index.js index 11ef888f..71549002 100644 --- a/src/modules/WebglDistort/index.js +++ b/src/modules/WebglDistort/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] \ No newline at end of file + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/WhiteBalance/Module.js b/src/modules/WhiteBalance/Module.js index cea97372..78c1300a 100644 --- a/src/modules/WhiteBalance/Module.js +++ b/src/modules/WhiteBalance/Module.js @@ -1,58 +1,58 @@ module.exports = function Balance(options, UI) { - var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); - options.red = options.red || defaults.red - options.green = options.green || defaults.green - options.blue = options.blue || defaults.blue + options.red = options.red || defaults.red; + options.green = options.green || defaults.green; + options.blue = options.blue || defaults.blue; - var output; + var output; - function draw(input, callback, progressObj) { + function draw(input, callback, progressObj) { - progressObj.stop(true); - progressObj.overrideFlag = true; + progressObj.stop(true); + progressObj.overrideFlag = true; - var step = this; + var step = this; - function extraManipulation(pixels) { + function extraManipulation(pixels) { - var i = 0 - var red_factor = 255/options.red - var green_factor = 255/options.green - var blue_factor = 255/options.blue + var i = 0; + var red_factor = 255/options.red; + var green_factor = 255/options.green; + var blue_factor = 255/options.blue; - while (i < pixels.data.length) { - pixels.data[i] = Math.min(255, pixels.data[i]*red_factor) - pixels.data[i+1] = Math.min(255, pixels.data[i+1]*green_factor) - pixels.data[i+2] = Math.min(255, pixels.data[i+2]*blue_factor) - i+=4 - } + while (i < pixels.data.length) { + pixels.data[i] = Math.min(255, pixels.data[i]*red_factor); + pixels.data[i+1] = Math.min(255, pixels.data[i+1]*green_factor); + pixels.data[i+2] = Math.min(255, pixels.data[i+2]*blue_factor); + i+=4; + } - return pixels - } - - function output(image, datauri, mimetype) { - - step.output = { src: datauri, format: mimetype }; - - } - - return require('../_nomodule/PixelManipulation.js')(input, { - output: output, - extraManipulation: extraManipulation, - format: input.format, - image: options.image, - inBrowser: options.inBrowser, - callback: callback - }); + return pixels; } - return { - options: options, - draw: draw, - output: output, - UI: UI + function output(image, datauri, mimetype) { + + step.output = { src: datauri, format: mimetype }; + } -} \ No newline at end of file + return require('../_nomodule/PixelManipulation.js')(input, { + output: output, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback + }); + } + + return { + options: options, + draw: draw, + output: output, + UI: UI + }; + +}; \ No newline at end of file diff --git a/src/modules/WhiteBalance/index.js b/src/modules/WhiteBalance/index.js index 49feec2b..981be0a5 100644 --- a/src/modules/WhiteBalance/index.js +++ b/src/modules/WhiteBalance/index.js @@ -1,4 +1,4 @@ module.exports = [ - require('./Module'), - require('./info.json') -] + require('./Module'), + require('./info.json') +]; diff --git a/src/modules/_nomodule/PixelManipulation.js b/src/modules/_nomodule/PixelManipulation.js index 0bf9bf2a..f272c422 100644 --- a/src/modules/_nomodule/PixelManipulation.js +++ b/src/modules/_nomodule/PixelManipulation.js @@ -13,12 +13,12 @@ module.exports = function PixelManipulation(image, options) { options = options || {}; - const getPixels = require("get-pixels"), - savePixels = require("save-pixels"); + const getPixels = require('get-pixels'), + savePixels = require('save-pixels'); getPixels(image.src, function(err, pixels) { if (err) { - console.log("Bad image path", image); + console.log('Bad image path', image); return; } @@ -34,7 +34,7 @@ module.exports = function PixelManipulation(image, options) { if (!options.inBrowser && !process.env.TEST) { try { - var pace = require("pace")(pixels.shape[0] * pixels.shape[1]); + var pace = require('pace')(pixels.shape[0] * pixels.shape[1]); } catch (e) { options.inBrowser = true; } @@ -78,14 +78,14 @@ module.exports = function PixelManipulation(image, options) { var r = savePixels(pixels, options.format, { quality: 100 }); - r.on("data", function(chunk) { + r.on('data', function(chunk) { totalLength += chunk.length; chunks.push(chunk); }); - r.on("end", function() { - var data = Buffer.concat(chunks, totalLength).toString("base64"); - var datauri = "data:image/" + options.format + ";base64," + data; + r.on('end', function() { + var data = Buffer.concat(chunks, totalLength).toString('base64'); + var datauri = 'data:image/' + options.format + ';base64,' + data; if (options.output) options.output(options.image, datauri, options.format); if (options.callback) options.callback(); diff --git a/src/modules/_nomodule/gl-context.js b/src/modules/_nomodule/gl-context.js index f16c6317..6a615cd5 100644 --- a/src/modules/_nomodule/gl-context.js +++ b/src/modules/_nomodule/gl-context.js @@ -1,37 +1,37 @@ module.exports = function runInBrowserContext(input, callback, step, options) { - // to ignore this from getting browserified - const puppeteer = eval('require')('puppeteer'); + // to ignore this from getting browserified + const puppeteer = eval('require')('puppeteer'); - //Stripped down version of options which is serializable - var minOptions = require("lodash").cloneDeep(options); - minOptions.step = options.step.name; + //Stripped down version of options which is serializable + var minOptions = require('lodash').cloneDeep(options); + minOptions.step = options.step.name; - var obj = { input: input, modOptions: minOptions } + var obj = { input: input, modOptions: minOptions }; - puppeteer.launch({headless: true, args:['--no-sandbox', '--disable-setuid-sandbox']}).then(function(browser) { - browser.newPage().then(page => { - /* Maybe there is a better way to this, loading the page coz localstorage API + puppeteer.launch({headless: true, args:['--no-sandbox', '--disable-setuid-sandbox']}).then(function(browser) { + browser.newPage().then(page => { + /* Maybe there is a better way to this, loading the page coz localstorage API is not available otherwise */ - page.goto("https://google.com").then(() => { - page.addScriptTag({ path: require('path').join(__dirname, '../../../dist/image-sequencer.js') }).then(() => { - page.evaluate((options) => { - return new Promise((resolve, reject) => { - var sequencer = ImageSequencer(); - sequencer.loadImage(options.input.src); - sequencer.addSteps(options.modOptions.step, options.modOptions); - sequencer.run(function cb(out) { - resolve(sequencer.steps[1].output.src) - }); - }) - }, obj).then(el => { - browser.close().then(() => { - step.output = { src: el, format: input.format }; - callback(); - }); - }); - }) + page.goto('https://google.com').then(() => { + page.addScriptTag({ path: require('path').join(__dirname, '../../../dist/image-sequencer.js') }).then(() => { + page.evaluate((options) => { + return new Promise((resolve, reject) => { + var sequencer = ImageSequencer(); + sequencer.loadImage(options.input.src); + sequencer.addSteps(options.modOptions.step, options.modOptions); + sequencer.run(function cb(out) { + resolve(sequencer.steps[1].output.src); + }); }); + }, obj).then(el => { + browser.close().then(() => { + step.output = { src: el, format: input.format }; + callback(); + }); + }); }); + }); }); -} + }); +}; diff --git a/src/modules/_nomodule/gpuUtils.js b/src/modules/_nomodule/gpuUtils.js index ae967beb..c17761a5 100644 --- a/src/modules/_nomodule/gpuUtils.js +++ b/src/modules/_nomodule/gpuUtils.js @@ -1,4 +1,4 @@ -const GPU = require('gpu.js').GPU +const GPU = require('gpu.js').GPU; /** * @method convolve @@ -10,9 +10,9 @@ const GPU = require('gpu.js').GPU */ const convolve = (arrays, kernel, options = {}) => { const pipeMode = options.pipeMode || false, - mode = options.mode || 'gpu' + mode = options.mode || 'gpu'; - const gpu = new GPU(mode != 'gpu' ? {mode} : {}) + const gpu = new GPU(mode != 'gpu' ? {mode} : {}); const arrayX = arrays[0][0].length, arrayY = arrays[0].length, @@ -32,38 +32,38 @@ const convolve = (arrays, kernel, options = {}) => { }`; const padIt = (array) => { - let out = [] + let out = []; for (var y = 0; y < array.length + paddingY * 2; y++){ - out.push([]) + out.push([]); for (var x = 0; x < array[0].length + paddingX * 2; x++){ const positionX = Math.min(Math.max(x - paddingX, 0), array[0].length - 1); const positionY = Math.min(Math.max(y - paddingY, 0), array.length - 1); - out[y].push(array[positionY][positionX]) + out[y].push(array[positionY][positionX]); } } - return out - } + return out; + }; const convolveKernel = gpu.createKernel(matConvFunc, { output: [arrayX, arrayY], pipeline: pipeMode - }) + }); let outs = []; for (var i = 0; i < arrays.length; i++){ - const paddedArray = padIt(arrays[i]) + const paddedArray = padIt(arrays[i]); - const outArr = convolveKernel(paddedArray, kernel) + const outArr = convolveKernel(paddedArray, kernel); - if (pipeMode) outs.push(outArr.toArray()) - else outs.push(outArr) + if (pipeMode) outs.push(outArr.toArray()); + else outs.push(outArr); } - return outs -} + return outs; +}; /** * @@ -74,21 +74,21 @@ const convolve = (arrays, kernel, options = {}) => { * @returns {Float32Array} */ const compute = (outputSize, computeFunc, constants, pipeMode) => { - computeFunc = computeFunc.toString() + computeFunc = computeFunc.toString(); const compute = gpu.createKernel(computeFunc, { output: outputSize, constants, pipeline: pipeMode - }) + }); - compute.build() + compute.build(); - if (pipeMode) return compute().toArray() - else return compute() -} + if (pipeMode) return compute().toArray(); + else return compute(); +}; module.exports = { convolve, compute -} \ No newline at end of file +}; \ No newline at end of file diff --git a/src/ui/LoadImage.js b/src/ui/LoadImage.js index bc81e782..4d5987b2 100644 --- a/src/ui/LoadImage.js +++ b/src/ui/LoadImage.js @@ -4,12 +4,12 @@ function LoadImage(ref, name, src, main_callback) { var image = { src: datauri, format: datauri.split(':')[1].split(';')[0].split('/')[1] - } + }; return image; } function CImage(src, step, callback) { var datauri; - if (!!src.match(/^data:/i)) { + if (src.match(/^data:/i)) { datauri = src; callback(datauri, step); } @@ -20,7 +20,7 @@ function LoadImage(ref, name, src, main_callback) { res.setEncoding('base64'); res.on('data', function(chunk) { data += chunk; }); res.on('end', function() { - callback("data:" + contentType + ";base64," + data, step); + callback('data:' + contentType + ';base64,' + data, step); }); }); } @@ -35,7 +35,7 @@ function LoadImage(ref, name, src, main_callback) { context.drawImage(image, 0, 0); datauri = canvas.toDataURL(ext); callback(datauri, step); - } + }; image.src = src; } else { @@ -46,8 +46,8 @@ function LoadImage(ref, name, src, main_callback) { function loadImage(name, src) { var step = { - name: "load-image", - description: "This initial step loads and displays the original image without any modifications.", + name: 'load-image', + description: 'This initial step loads and displays the original image without any modifications.', ID: ref.options.sequencerCounter++, inBrowser: ref.options.inBrowser, ui: ref.options.ui, diff --git a/src/ui/SetInputStep.js b/src/ui/SetInputStep.js index 2a377548..269c33ce 100644 --- a/src/ui/SetInputStep.js +++ b/src/ui/SetInputStep.js @@ -49,28 +49,28 @@ function setInputStepInit() { }; document.getElementById('close').addEventListener('click', function () { stopStream(stream); - }); + }); } function handleError(error) { console.log('navigator.getUserMedia error: ', error); } - navigator.mediaDevices.getUserMedia(constraints).then(handleSuccess).catch(handleError); + navigator.mediaDevices.getUserMedia(constraints).then(handleSuccess).catch(handleError); - document.getElementById('capture').addEventListener('click', function(stream){ - context.drawImage(video, 0, 0, 400, 300); - options.onTakePhoto(canvas.toDataURL()); - }); + document.getElementById('capture').addEventListener('click', function(stream){ + context.drawImage(video, 0, 0, 400, 300); + options.onTakePhoto(canvas.toDataURL()); + }); - function stopStream(stream) { - stream.getVideoTracks().forEach(function (track) { - track.stop(); - }); - document.getElementById('video').style.display='none'; - document.getElementById('capture').style.display='none'; - document.getElementById('close').style.display='none'; - } -} + function stopStream(stream) { + stream.getVideoTracks().forEach(function (track) { + track.stop(); + }); + document.getElementById('video').style.display='none'; + document.getElementById('capture').style.display='none'; + document.getElementById('close').style.display='none'; + } + } fileInput.on('change', handleFile); takePhoto.on('click', runVideo); @@ -91,7 +91,7 @@ function setInputStepInit() { dropzone.removeClass('hover'); }); - } + }; } module.exports = setInputStepInit; diff --git a/src/ui/UserInterface.js b/src/ui/UserInterface.js index 560c19ef..d8ace0b6 100644 --- a/src/ui/UserInterface.js +++ b/src/ui/UserInterface.js @@ -6,27 +6,27 @@ module.exports = function UserInterface(events = {}) { events.onSetup = events.onSetup || function(step) { if (step.ui == false) { - // No UI + // No UI } else if(step.inBrowser) { // Create and append an HTML Element - console.log("Added Step \""+step.name+"\""); + console.log('Added Step "'+step.name+'"'); } else { // Create a NodeJS Object - console.log('\x1b[36m%s\x1b[0m',"Added Step \""+step.name+"\""); + console.log('\x1b[36m%s\x1b[0m','Added Step "'+step.name+'"'); } - } + }; events.onDraw = events.onDraw || function(step) { if (step.ui == false) { // No UI } else if(step.inBrowser) { // Overlay a loading spinner - console.log("Drawing Step \""+step.name+"\""); + console.log('Drawing Step "'+step.name+'"'); } else { // Don't do anything - console.log('\x1b[33m%s\x1b[0m',"Drawing Step \""+step.name+"\""); + console.log('\x1b[33m%s\x1b[0m','Drawing Step "'+step.name+'"'); } - } + }; events.onComplete = events.onComplete || function(step) { if (step.ui == false) { @@ -34,29 +34,29 @@ module.exports = function UserInterface(events = {}) { } else if(step.inBrowser) { // Update the DIV Element // Hide the laoding spinner - console.log("Drawn Step \""+step.name+"\""); + console.log('Drawn Step "'+step.name+'"'); } else { // Update the NodeJS Object - console.log('\x1b[32m%s\x1b[0m',"Drawn Step \""+step.name+"\""); + console.log('\x1b[32m%s\x1b[0m','Drawn Step "'+step.name+'"'); } - } + }; events.onRemove = events.onRemove || function(step) { if (step.ui == false){ // No UI } else if(step.inBrowser) { // Remove the DIV Element - console.log("Removing Step \""+step.name+"\""); + console.log('Removing Step "'+step.name+'"'); } else { // Delete the NodeJS Object - console.log('\x1b[31m%s\x1b[0m',"Removing Step \""+step.name+"\""); + console.log('\x1b[31m%s\x1b[0m','Removing Step "'+step.name+'"'); } - } + }; events.notify = events.notify || function(msg) { - console.log(msg); - } + console.log(msg); + }; return events; -} +}; diff --git a/src/ui/prepareDynamic.js b/src/ui/prepareDynamic.js index 4affb7a0..55258c67 100644 --- a/src/ui/prepareDynamic.js +++ b/src/ui/prepareDynamic.js @@ -1,7 +1,7 @@ var sequencer = []; var module = { - exports: {}, - set exports(val){ - sequencer.push(val); - } -} + exports: {}, + set exports(val){ + sequencer.push(val); + } +}; diff --git a/src/util/GetFormat.js b/src/util/GetFormat.js index e5c02b41..74bb7993 100644 --- a/src/util/GetFormat.js +++ b/src/util/GetFormat.js @@ -17,12 +17,12 @@ module.exports = function GetFormat(src) { } function isDataUrl(src) { - return src.substr(0, 10) === "data:image" + return src.substr(0, 10) === 'data:image'; } format = format.toLowerCase(); - if (format === "jpeg") format = "jpg"; + if (format === 'jpeg') format = 'jpg'; function validateFormat(data){ let supportedFormats = [ @@ -37,4 +37,4 @@ module.exports = function GetFormat(src) { return validateFormat(format)?format:'jpg'; -} +}; diff --git a/src/util/ParseInputCoordinates.js b/src/util/ParseInputCoordinates.js index 5453a24f..68302d98 100644 --- a/src/util/ParseInputCoordinates.js +++ b/src/util/ParseInputCoordinates.js @@ -1,24 +1,24 @@ module.exports = function parseCornerCoordinateInputs(options,coord,callback) { - var getPixels = require('get-pixels'); - getPixels(coord.src, function(err, pixels) { - var iw = pixels.shape[0], - ih = pixels.shape[1]; - if (!coord.x.valInp) { - return - } - else { - Object.keys(coord).forEach(convert); - function convert(key) { - var val = coord[key]; - if (val.valInp && val.valInp.slice(-1) === "%") { - val.valInp = parseInt(val.valInp, 10); - if (val.type === 'horizontal') - val.valInp = val.valInp * iw / 100; - else - val.valInp = val.valInp * ih / 100; - } + var getPixels = require('get-pixels'); + getPixels(coord.src, function(err, pixels) { + var iw = pixels.shape[0], + ih = pixels.shape[1]; + if (!coord.x.valInp) { + return; + } + else { + Object.keys(coord).forEach(convert); + function convert(key) { + var val = coord[key]; + if (val.valInp && val.valInp.slice(-1) === '%') { + val.valInp = parseInt(val.valInp, 10); + if (val.type === 'horizontal') + val.valInp = val.valInp * iw / 100; + else + val.valInp = val.valInp * ih / 100; } } - callback(options, coord); - }) - } \ No newline at end of file + } + callback(options, coord); + }); +}; \ No newline at end of file diff --git a/src/util/createMetaModule.js b/src/util/createMetaModule.js index 35ccc292..2cb6dbca 100644 --- a/src/util/createMetaModule.js +++ b/src/util/createMetaModule.js @@ -57,8 +57,8 @@ module.exports = function createMetaModule(mapFunction, moduleOptions) { draw: draw, output: output, UI: UI - } + }; } return [MetaModule, moduleOptions.infoJson]; -} +}; diff --git a/src/util/getDefaults.js b/src/util/getDefaults.js index d4385987..308f73c1 100644 --- a/src/util/getDefaults.js +++ b/src/util/getDefaults.js @@ -6,4 +6,4 @@ module.exports = function(info){ } } return defaults; -} +}; diff --git a/src/util/getStep.js b/src/util/getStep.js index f32e23db..2aaeb9cf 100644 --- a/src/util/getStep.js +++ b/src/util/getStep.js @@ -1,49 +1,49 @@ module.exports = { - getPreviousStep: function() { - return this.getStep(-1); - }, + getPreviousStep: function() { + return this.getStep(-1); + }, - getNextStep: function() { - return this.getStep(1); - }, + getNextStep: function() { + return this.getStep(1); + }, - getInput: function(offset) { - if (offset + this.getIndex() === 0) offset++; - return this.getStep(offset - 1).output; - }, + getInput: function(offset) { + if (offset + this.getIndex() === 0) offset++; + return this.getStep(offset - 1).output; + }, - getOutput: function(offset) { - return this.getStep(offset).output; - }, + getOutput: function(offset) { + return this.getStep(offset).output; + }, - getOptions: function() { - return this.getStep(0).options; - }, + getOptions: function() { + return this.getStep(0).options; + }, - setOptions: function(optionsObj) { - let options = this.getStep(0).options; - for (let key in optionsObj) { - if (options[key]) options[key] = optionsObj[key]; - } - }, - - getFormat: function() { - return this.getStep(-1).output.format; - }, - - getHeight: function(callback) { - let img = new Image(); - img.onload = function() { - callback(img.height); - }; - img.src = this.getInput(0).src; - }, - - getWidth: function(callback) { - let img = new Image(); - img.onload = function() { - callback(img.width); - }; - img.src = this.getInput(0).src; + setOptions: function(optionsObj) { + let options = this.getStep(0).options; + for (let key in optionsObj) { + if (options[key]) options[key] = optionsObj[key]; } -} \ No newline at end of file + }, + + getFormat: function() { + return this.getStep(-1).output.format; + }, + + getHeight: function(callback) { + let img = new Image(); + img.onload = function() { + callback(img.height); + }; + img.src = this.getInput(0).src; + }, + + getWidth: function(callback) { + let img = new Image(); + img.onload = function() { + callback(img.width); + }; + img.src = this.getInput(0).src; + } +}; \ No newline at end of file diff --git a/src/util/parseDistortCoordinates.js b/src/util/parseDistortCoordinates.js index 39430ce9..97d0abb3 100644 --- a/src/util/parseDistortCoordinates.js +++ b/src/util/parseDistortCoordinates.js @@ -1,16 +1,16 @@ module.exports = function parseDistortCoordinates(options) { - let coord = [] - coord.push(options.nw.split(',')) - coord.push(options.ne.split(',')) - coord.push(options.se.split(',')) - coord.push(options.sw.split(',')) + let coord = []; + coord.push(options.nw.split(',')); + coord.push(options.ne.split(',')); + coord.push(options.se.split(',')); + coord.push(options.sw.split(',')); let parsedCoord = coord.reduce((acc, val) => { - acc.push(parseInt(val[0])) - acc.push(parseInt(val[1])) - return acc - }, []) + acc.push(parseInt(val[0])); + acc.push(parseInt(val[1])); + return acc; + }, []); - return parsedCoord -} \ No newline at end of file + return parsedCoord; +}; \ No newline at end of file diff --git a/test/core/cli.js b/test/core/cli.js index a284e792..7a1c307a 100644 --- a/test/core/cli.js +++ b/test/core/cli.js @@ -4,10 +4,10 @@ const cliUtils = require('../../src/CliUtils'); const test = require('tape'); test('Output directory is correctly generated',function(t){ - cliUtils.makedir('./output/',function(){ - require('fs').access('./output/.',function(err){ - t.true(!err,"Access the created dir"); - t.end(); - }); + cliUtils.makedir('./output/',function(){ + require('fs').access('./output/.',function(err){ + t.true(!err,'Access the created dir'); + t.end(); }); + }); }); diff --git a/test/core/images/IS-QR.js b/test/core/images/IS-QR.js index 5e01ceae..3e3269ed 100644 --- a/test/core/images/IS-QR.js +++ b/test/core/images/IS-QR.js @@ -1 +1 @@ -module.exports = ""; +module.exports = ''; diff --git a/test/core/images/test.gif.js b/test/core/images/test.gif.js index fce3817e..0e6c03ff 100644 --- a/test/core/images/test.gif.js +++ b/test/core/images/test.gif.js @@ -1 +1 @@ -module.exports = ""; +module.exports = ''; diff --git a/test/core/images/test.png.js b/test/core/images/test.png.js index d0d6126c..de221ae9 100644 --- a/test/core/images/test.png.js +++ b/test/core/images/test.png.js @@ -1 +1 @@ -module.exports = ""; +module.exports = ''; diff --git a/test/core/modules/add-qr.js b/test/core/modules/add-qr.js index 6e4f8ed5..032352a4 100644 --- a/test/core/modules/add-qr.js +++ b/test/core/modules/add-qr.js @@ -2,4 +2,4 @@ const testModule = require('../templates/module-test'), options = {size:200, qrCodeString:'https://github.com/publiclab/image-sequencer'}, benchmark= ''; -testModule('add-qr', options, benchmark) \ No newline at end of file +testModule('add-qr', options, benchmark); \ No newline at end of file diff --git a/test/core/modules/blend.js b/test/core/modules/blend.js index 85427869..3e738684 100644 --- a/test/core/modules/blend.js +++ b/test/core/modules/blend.js @@ -10,42 +10,42 @@ const test = require('tape'), let benchmark = ''; -let sequencer = ImageSequencer({ui: false}) +let sequencer = ImageSequencer({ui: false}); -test(`blend module loads correctly`, t => { - sequencer.loadImages(image) - sequencer.addSteps('brightness', {}) - sequencer.addSteps('blend', options) +test('blend module loads correctly', t => { + sequencer.loadImages(image); + sequencer.addSteps('brightness', {}); + sequencer.addSteps('blend', options); - t.equal(sequencer.steps[2].options.name, 'blend', `blend module is getting loaded`) - t.end() -}) + t.equal(sequencer.steps[2].options.name, 'blend', 'blend module is getting loaded'); + t.end(); +}); -test(`blend module loads with correct options`, t => { +test('blend module loads with correct options', t => { for (const option in options) { - t.equal(sequencer.steps[2].options[option], options[option], `Option ${option} is correct`) + t.equal(sequencer.steps[2].options[option], options[option], `Option ${option} is correct`); } t.end(); -}) +}); -test(`blend module works correctly`, t => { +test('blend module works correctly', t => { sequencer.run({mode: 'test'}, () => { - let result = sequencer.steps[2].output.src + let result = sequencer.steps[2].output.src; - base64Img.imgSync(result, target, 'result') - base64Img.imgSync(benchmark, target, 'benchmark') + base64Img.imgSync(result, target, 'result'); + base64Img.imgSync(benchmark, target, 'benchmark'); - result = './test_outputs/result.png' - benchmark = './test_outputs/benchmark.png' + result = './test_outputs/result.png'; + benchmark = './test_outputs/benchmark.png'; looksSame(result, benchmark, function(err, res) { - if (err) console.log(err) + if (err) console.log(err); - t.equal(res.equal, true, `blend module works correctly`) - sequencer = null - t.end() - }) - }) -}) \ No newline at end of file + t.equal(res.equal, true, 'blend module works correctly'); + sequencer = null; + t.end(); + }); + }); +}); \ No newline at end of file diff --git a/test/core/modules/blur.js b/test/core/modules/blur.js index 688bbba4..e3a60fa8 100644 --- a/test/core/modules/blur.js +++ b/test/core/modules/blur.js @@ -1,5 +1,5 @@ -const benchmark = "", +const benchmark = '', moduleTest = require('../templates/module-test'); -moduleTest('blur', {blur: 3.25}, benchmark) +moduleTest('blur', {blur: 3.25}, benchmark); diff --git a/test/core/modules/brightness.js b/test/core/modules/brightness.js index d560e5f5..a93b33a5 100644 --- a/test/core/modules/brightness.js +++ b/test/core/modules/brightness.js @@ -1,4 +1,4 @@ -const benchmark = "", +const benchmark = '', testModule = require('../templates/module-test'); -testModule('brightness', {brightness: 1}, benchmark) \ No newline at end of file +testModule('brightness', {brightness: 1}, benchmark); \ No newline at end of file diff --git a/test/core/modules/canvas-resize.js b/test/core/modules/canvas-resize.js index dda86a11..8ee04650 100644 --- a/test/core/modules/canvas-resize.js +++ b/test/core/modules/canvas-resize.js @@ -4,31 +4,31 @@ require('../../../src/ImageSequencer.js'); var sequencer = ImageSequencer({ ui: false }); var options = { width: 500, height: 500 }; -var red = ""; +var red = ''; // Test 1 to check brightness module is getting loaded test('Load canvas-resize module', function(t) { - sequencer.loadImages(red); - sequencer.addSteps('canvas-resize', options); - t.equal(sequencer.steps[1].options.name, 'canvas-resize', 'Canvas resize module is getting loaded'); - t.end(); + sequencer.loadImages(red); + sequencer.addSteps('canvas-resize', options); + t.equal(sequencer.steps[1].options.name, 'canvas-resize', 'Canvas resize module is getting loaded'); + t.end(); }); // Test 2 to check options are correct test('Check Options', function(t) { - t.equal(sequencer.steps[1].options.width, 500, 'Options are correct'); - t.equal(sequencer.steps[1].options.height, 500, 'Options are correct'); - t.end(); + t.equal(sequencer.steps[1].options.width, 500, 'Options are correct'); + t.equal(sequencer.steps[1].options.height, 500, 'Options are correct'); + t.end(); }); // Test 3 to check brightness module works as expected test('canvas-resize module works correctly', function(t) { - sequencer.run({ mode: 'test' }, function(out) { - var result = sequencer.steps[1].output.src; - require('get-pixels')(result, (err, pix) => { - t.equal(pix.shape[0], 500); - t.equal(pix.shape[1], 500); - t.end(); - }); + sequencer.run({ mode: 'test' }, function(out) { + var result = sequencer.steps[1].output.src; + require('get-pixels')(result, (err, pix) => { + t.equal(pix.shape[0], 500); + t.equal(pix.shape[1], 500); + t.end(); }); + }); }); \ No newline at end of file diff --git a/test/core/modules/channel.js b/test/core/modules/channel.js index 235a5324..704f53d7 100644 --- a/test/core/modules/channel.js +++ b/test/core/modules/channel.js @@ -1,4 +1,4 @@ -const benchmark = "", +const benchmark = '', testModule = require('../templates/module-test'); -testModule('channel', {channel: 'red'}, benchmark) +testModule('channel', {channel: 'red'}, benchmark); diff --git a/test/core/modules/color-temperature.js b/test/core/modules/color-temperature.js index 77ec23dc..7aa0d202 100644 --- a/test/core/modules/color-temperature.js +++ b/test/core/modules/color-temperature.js @@ -4,4 +4,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('color-temperature', options, benchmark) \ No newline at end of file +testModule('color-temperature', options, benchmark); \ No newline at end of file diff --git a/test/core/modules/colorbar.js b/test/core/modules/colorbar.js index c27997da..ae7a5d09 100644 --- a/test/core/modules/colorbar.js +++ b/test/core/modules/colorbar.js @@ -8,4 +8,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('colorbar', options, benchmark, image) \ No newline at end of file +testModule('colorbar', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/colormap.js b/test/core/modules/colormap.js index 220f7f0b..0b1e778a 100644 --- a/test/core/modules/colormap.js +++ b/test/core/modules/colormap.js @@ -1,6 +1,6 @@ -const benchmark = "", +const benchmark = '', testModule = require('../templates/module-test'); -testModule('colormap', {colormap: 'blutoredjet'}, benchmark) +testModule('colormap', {colormap: 'blutoredjet'}, benchmark); diff --git a/test/core/modules/contrast.js b/test/core/modules/contrast.js index 9aa421cc..425af089 100644 --- a/test/core/modules/contrast.js +++ b/test/core/modules/contrast.js @@ -1,4 +1,4 @@ -const benchmark = "", +const benchmark = '', testModule = require('../templates/module-test'); -testModule('contrast', {contrast: -40}, benchmark) \ No newline at end of file +testModule('contrast', {contrast: -40}, benchmark); \ No newline at end of file diff --git a/test/core/modules/convolution.js b/test/core/modules/convolution.js index a08ef599..6a832a5e 100644 --- a/test/core/modules/convolution.js +++ b/test/core/modules/convolution.js @@ -6,4 +6,4 @@ const testModule = require('../templates/module-test'), kernelValues: '1 0 1 0 1 0 1 0 1' }; -testModule('convolution', options, benchmark, image) \ No newline at end of file +testModule('convolution', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/crop.js b/test/core/modules/crop.js index fc757ed2..5b85e50f 100644 --- a/test/core/modules/crop.js +++ b/test/core/modules/crop.js @@ -8,4 +8,4 @@ const testModule = require('../templates/module-test'), h: '45' }; -testModule('crop', options, benchmark, image) \ No newline at end of file +testModule('crop', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/decode-qr.js b/test/core/modules/decode-qr.js index e393f767..e977d58c 100644 --- a/test/core/modules/decode-qr.js +++ b/test/core/modules/decode-qr.js @@ -15,8 +15,8 @@ test('Load Decode-Qr module', function(t) { test('Decode-qr module works correctly', function(t) { sequencer.run({ mode: 'test' }, function(out) { - var result = sequencer.steps[1].options.step.qrval; - t.equal(result, "http://github.com/publiclab/image-sequencer", 'should be equal'); - t.end(); - }) -}) \ No newline at end of file + var result = sequencer.steps[1].options.step.qrval; + t.equal(result, 'http://github.com/publiclab/image-sequencer', 'should be equal'); + t.end(); + }); +}); \ No newline at end of file diff --git a/test/core/modules/dither.js b/test/core/modules/dither.js index 1f9043b9..bd48d79a 100644 --- a/test/core/modules/dither.js +++ b/test/core/modules/dither.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), - benchmark = ""; + benchmark = ''; -testModule('dither', {dither: 'bayer'}, benchmark) \ No newline at end of file +testModule('dither', {dither: 'bayer'}, benchmark); \ No newline at end of file diff --git a/test/core/modules/draw-rectangle.js b/test/core/modules/draw-rectangle.js index 3108545f..d7b09650 100644 --- a/test/core/modules/draw-rectangle.js +++ b/test/core/modules/draw-rectangle.js @@ -10,4 +10,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('draw-rectangle', options, benchmark, image) \ No newline at end of file +testModule('draw-rectangle', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/dynamic.js b/test/core/modules/dynamic.js index 43f7c636..245dbdd1 100644 --- a/test/core/modules/dynamic.js +++ b/test/core/modules/dynamic.js @@ -7,4 +7,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('dynamic', options, benchmark, image) \ No newline at end of file +testModule('dynamic', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/edge-detect.js b/test/core/modules/edge-detect.js index 33bd88e1..548e95ca 100644 --- a/test/core/modules/edge-detect.js +++ b/test/core/modules/edge-detect.js @@ -1,5 +1,5 @@ const testModule = require('../templates/module-test'), - benchmark = "", + benchmark = '', image = require('../images/IS-QR'), options = { blur: 1.8, diff --git a/test/core/modules/exposure.js b/test/core/modules/exposure.js index c2ff57f7..ac8921fc 100644 --- a/test/core/modules/exposure.js +++ b/test/core/modules/exposure.js @@ -5,4 +5,4 @@ const testModule = require('../templates/module-test'), exposure: 3 }; -testModule('exposure', options, benchmark, image) \ No newline at end of file +testModule('exposure', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/fisheye-gl.js b/test/core/modules/fisheye-gl.js index 1ce4ee01..449f1f64 100644 --- a/test/core/modules/fisheye-gl.js +++ b/test/core/modules/fisheye-gl.js @@ -11,4 +11,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('fisheye-gl', options, benchmark, image) \ No newline at end of file +testModule('fisheye-gl', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/gamma-correction.js b/test/core/modules/gamma-correction.js index beff7f4d..32c9e3d9 100644 --- a/test/core/modules/gamma-correction.js +++ b/test/core/modules/gamma-correction.js @@ -5,4 +5,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('gamma-correction', options, benchmark, image) \ No newline at end of file +testModule('gamma-correction', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/gradient.js b/test/core/modules/gradient.js index 06345638..5be6ee89 100644 --- a/test/core/modules/gradient.js +++ b/test/core/modules/gradient.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), benchmark = ''; -testModule('gradient', {}, benchmark) \ No newline at end of file +testModule('gradient', {}, benchmark); \ No newline at end of file diff --git a/test/core/modules/grid-overlay.js b/test/core/modules/grid-overlay.js index 60f51c6b..39902543 100644 --- a/test/core/modules/grid-overlay.js +++ b/test/core/modules/grid-overlay.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), - benchmark = ""; + benchmark = ''; -testModule('grid-overlay', {x: 1}, benchmark) \ No newline at end of file +testModule('grid-overlay', {x: 1}, benchmark); \ No newline at end of file diff --git a/test/core/modules/histogram.js b/test/core/modules/histogram.js index e180e56e..38bfbf50 100644 --- a/test/core/modules/histogram.js +++ b/test/core/modules/histogram.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), benchmark = ''; -testModule('histogram', {}, benchmark) \ No newline at end of file +testModule('histogram', {}, benchmark); \ No newline at end of file diff --git a/test/core/modules/invert.js b/test/core/modules/invert.js index 22b9b39f..f583348e 100644 --- a/test/core/modules/invert.js +++ b/test/core/modules/invert.js @@ -12,30 +12,30 @@ require('../../../src/ImageSequencer.js'); //require image files as DataURLs so they can be tested alike on browser and Node. var sequencer = ImageSequencer({ ui: false }); -var target = 'test_outputs' +var target = 'test_outputs'; -var red = ""; -var invert = ""; +var red = ''; +var invert = ''; //Tests for Invert module -test("Load invert module", function(t) { +test('Load invert module', function(t) { sequencer.loadImages( red); - t.equal(sequencer.steps.length, 1,'Image loaded') + t.equal(sequencer.steps.length, 1,'Image loaded'); sequencer.addSteps('invert'); - t.equal(sequencer.steps[1].options.name, 'invert', 'Invert step added') - t.end() -}) + t.equal(sequencer.steps[1].options.name, 'invert', 'Invert step added'); + t.end(); +}); -test("Inverted image isn't identical", function(t) { +test('Inverted image isn\'t identical', function(t) { sequencer.run({ mode: 'test' }, function(out) { var input = sequencer.steps[0].output.src; var output = sequencer.steps[1].output.src; input = DataURItoBuffer(input); output = DataURItoBuffer(output); - t.notEqual(input,output,'Not equal') - t.end() - }) + t.notEqual(input,output,'Not equal'); + t.end(); + }); }); // test("Twice inverted image is identical to original image", function(t) { @@ -55,18 +55,18 @@ test("Inverted image isn't identical", function(t) { // }) // }); -test("Invert module produces correct output", function(t) { +test('Invert module produces correct output', function(t) { sequencer.run({ mode: 'test' }, function(out) { - var result = sequencer.steps[1].output.src - var benchmark = invert - base64Img.imgSync(result, target, 'result') - base64Img.imgSync(benchmark, target, 'benchmark') - result = './test_outputs/result.png' - benchmark = './test_outputs/benchmark.png' + var result = sequencer.steps[1].output.src; + var benchmark = invert; + base64Img.imgSync(result, target, 'result'); + base64Img.imgSync(benchmark, target, 'benchmark'); + result = './test_outputs/result.png'; + benchmark = './test_outputs/benchmark.png'; looksSame(result, benchmark, function(err, res) { - if (err) console.log(err) - t.equal(res.equal, true) - t.end() - }) - }) -}) \ No newline at end of file + if (err) console.log(err); + t.equal(res.equal, true); + t.end(); + }); + }); +}); \ No newline at end of file diff --git a/test/core/modules/ndvi-colormap.js b/test/core/modules/ndvi-colormap.js index 3fc02b90..cb8cc2a9 100644 --- a/test/core/modules/ndvi-colormap.js +++ b/test/core/modules/ndvi-colormap.js @@ -2,4 +2,4 @@ const testModule = require('../templates/module-test'), image = require('../images/IS-QR'), benchmark = ''; -testModule('ndvi-colormap', {}, benchmark, image) \ No newline at end of file +testModule('ndvi-colormap', {}, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/ndvi.js b/test/core/modules/ndvi.js index 432c44e5..6eb2bdb9 100644 --- a/test/core/modules/ndvi.js +++ b/test/core/modules/ndvi.js @@ -5,4 +5,4 @@ const testModule = require('../templates/module-test'), filter: 'blue' }; -testModule('ndvi', options, benchmark, image) \ No newline at end of file +testModule('ndvi', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/overlay.js b/test/core/modules/overlay.js index 52d4e446..b29293f9 100644 --- a/test/core/modules/overlay.js +++ b/test/core/modules/overlay.js @@ -10,42 +10,42 @@ const test = require('tape'), let benchmark = ''; -let sequencer = ImageSequencer({ui: false}) +let sequencer = ImageSequencer({ui: false}); -test(`overlay module loads correctly`, t => { - sequencer.loadImages(image) - sequencer.addSteps('colorbar', {}) - sequencer.addSteps('overlay', options) +test('overlay module loads correctly', t => { + sequencer.loadImages(image); + sequencer.addSteps('colorbar', {}); + sequencer.addSteps('overlay', options); - t.equal(sequencer.steps[2].options.name, 'overlay', `overlay module is getting loaded`) - t.end() -}) + t.equal(sequencer.steps[2].options.name, 'overlay', 'overlay module is getting loaded'); + t.end(); +}); -test(`overlay module loads with correct options`, t => { +test('overlay module loads with correct options', t => { for (const option in options) { - t.equal(sequencer.steps[2].options[option], options[option], `Option ${option} is correct`) + t.equal(sequencer.steps[2].options[option], options[option], `Option ${option} is correct`); } t.end(); -}) +}); -test(`overlay module works correctly`, t => { +test('overlay module works correctly', t => { sequencer.run({mode: 'test'}, () => { - let result = sequencer.steps[2].output.src + let result = sequencer.steps[2].output.src; - base64Img.imgSync(result, target, 'result') - base64Img.imgSync(benchmark, target, 'benchmark') + base64Img.imgSync(result, target, 'result'); + base64Img.imgSync(benchmark, target, 'benchmark'); - result = './test_outputs/result.png' - benchmark = './test_outputs/benchmark.png' + result = './test_outputs/result.png'; + benchmark = './test_outputs/benchmark.png'; looksSame(result, benchmark, function(err, res) { - if (err) console.log(err) + if (err) console.log(err); - t.equal(res.equal, true, `overlay module works correctly`) - sequencer = null - t.end() - }) - }) -}) \ No newline at end of file + t.equal(res.equal, true, 'overlay module works correctly'); + sequencer = null; + t.end(); + }); + }); +}); \ No newline at end of file diff --git a/test/core/modules/paint-bucket.js b/test/core/modules/paint-bucket.js index f109a8e5..3162dc62 100644 --- a/test/core/modules/paint-bucket.js +++ b/test/core/modules/paint-bucket.js @@ -8,4 +8,4 @@ const testModule = require('../templates/module-test'), }, benchmark = ''; -testModule('paint-bucket', options, benchmark, image) \ No newline at end of file +testModule('paint-bucket', options, benchmark, image); \ No newline at end of file diff --git a/test/core/modules/replace-color.js b/test/core/modules/replace-color.js index ee070dbc..c09a5793 100644 --- a/test/core/modules/replace-color.js +++ b/test/core/modules/replace-color.js @@ -1,9 +1,9 @@ const testModule = require('../templates/module-test'), options = { - "replaceMethod": "greyscale", - "color": "255 0 0", - "tolerance": "50" + 'replaceMethod': 'greyscale', + 'color': '255 0 0', + 'tolerance': '50' }, - benchmark = ""; + benchmark = ''; -testModule('replace-color', options, benchmark) \ No newline at end of file +testModule('replace-color', options, benchmark); \ No newline at end of file diff --git a/test/core/modules/resize.js b/test/core/modules/resize.js index 8fe763c1..cecaa252 100644 --- a/test/core/modules/resize.js +++ b/test/core/modules/resize.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), - benchmark = ""; + benchmark = ''; -testModule('resize', {resize: '129%'}, benchmark) \ No newline at end of file +testModule('resize', {resize: '129%'}, benchmark); \ No newline at end of file diff --git a/test/core/modules/rotate.js b/test/core/modules/rotate.js index 006c7d9c..3724f4db 100644 --- a/test/core/modules/rotate.js +++ b/test/core/modules/rotate.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), - benchmark = ""; + benchmark = ''; -testModule('rotate', {rotate: 45}, benchmark) \ No newline at end of file +testModule('rotate', {rotate: 45}, benchmark); \ No newline at end of file diff --git a/test/core/modules/saturation.js b/test/core/modules/saturation.js index e3d0e134..3dc482bb 100644 --- a/test/core/modules/saturation.js +++ b/test/core/modules/saturation.js @@ -4,4 +4,4 @@ const testModule = require('../templates/module-test'), saturation: 1.2 }; -testModule('saturation', options, benchmark) \ No newline at end of file +testModule('saturation', options, benchmark); \ No newline at end of file diff --git a/test/core/modules/text-overlay.js b/test/core/modules/text-overlay.js index daa7d662..eae1e02d 100644 --- a/test/core/modules/text-overlay.js +++ b/test/core/modules/text-overlay.js @@ -5,9 +5,9 @@ var looksSame = require('looks-same'); require('../../../src/ImageSequencer.js'); var sequencer = ImageSequencer({ ui: false }); -var options = {text : "Hello World"}; +var options = {text : 'Hello World'}; var target = 'test_outputs'; -var red = ""; +var red = ''; // Test 1 to check text overlay module is getting loaded. test('Load Text Overlay module', function(t) { @@ -19,7 +19,7 @@ test('Load Text Overlay module', function(t) { // Test 2 to check options are correct. test('Check Options', function(t) { - t.equal(sequencer.steps[1].options.text, "Hello World", 'Options are correct'); + t.equal(sequencer.steps[1].options.text, 'Hello World', 'Options are correct'); t.end(); }); @@ -28,15 +28,15 @@ test('Text Overlay module works correctly', function(t) { sequencer.run({ mode: 'test' }, function(out) { // The test runs in node , and the text overlay is a browser only module, // thus it there is no image processing and output is same as input. - var result = sequencer.steps[1].output.src - base64Img.imgSync(result, target, 'result') - base64Img.imgSync(red, target, 'red') - result = './test_outputs/result.png' - red = './test_outputs/red.png' + var result = sequencer.steps[1].output.src; + base64Img.imgSync(result, target, 'result'); + base64Img.imgSync(red, target, 'red'); + result = './test_outputs/result.png'; + red = './test_outputs/red.png'; looksSame(result, red, function(err, res) { - if (err) console.log(err) - t.equal(res.equal, true) - t.end() - }) - }) -}) \ No newline at end of file + if (err) console.log(err); + t.equal(res.equal, true); + t.end(); + }); + }); +}); \ No newline at end of file diff --git a/test/core/modules/threshold.js b/test/core/modules/threshold.js index a3196a88..4a8555c0 100644 --- a/test/core/modules/threshold.js +++ b/test/core/modules/threshold.js @@ -1,4 +1,4 @@ const testModule = require('../templates/module-test'), - benchmark = ""; + benchmark = ''; -testModule('threshold', {threshold: 'Automatic Thresholding'}, benchmark) +testModule('threshold', {threshold: 'Automatic Thresholding'}, benchmark); diff --git a/test/core/modules/tint.js b/test/core/modules/tint.js index a4c3d083..72e43c6a 100644 --- a/test/core/modules/tint.js +++ b/test/core/modules/tint.js @@ -3,6 +3,6 @@ const testModule = require('../templates/module-test'), options = { color: '30, 40, 190', factor: 0.6 - } + }; testModule('tint', options, benchmark); \ No newline at end of file diff --git a/test/core/modules/webgl-distort.js b/test/core/modules/webgl-distort.js index 9717b306..da56b4da 100644 --- a/test/core/modules/webgl-distort.js +++ b/test/core/modules/webgl-distort.js @@ -5,6 +5,6 @@ const testModule = require('../templates/module-test'), se: '10,5', sw: '0,4' }, - benchmark = ""; + benchmark = ''; -testModule('webgl-distort', options, benchmark) +testModule('webgl-distort', options, benchmark); diff --git a/test/core/modules/white-balance.js b/test/core/modules/white-balance.js index bdcff6bf..1723b200 100644 --- a/test/core/modules/white-balance.js +++ b/test/core/modules/white-balance.js @@ -2,4 +2,4 @@ const testModule = require('../templates/module-test'), options = {red: 240, green: 240, blue: 240}, benchmark = ''; -testModule('white-balance', options, benchmark) \ No newline at end of file +testModule('white-balance', options, benchmark); \ No newline at end of file diff --git a/test/core/sequencer/benchmark.js b/test/core/sequencer/benchmark.js index 86fe511d..76b62648 100644 --- a/test/core/sequencer/benchmark.js +++ b/test/core/sequencer/benchmark.js @@ -6,42 +6,42 @@ var DataURItoBuffer = require('data-uri-to-buffer'); ImageSequencer = require('../../../src/ImageSequencer.js'); -var image = ""; +var image = ''; var imageName = 'image1'; test('benchmark all modules', function(t) { - console.log("############ Benchmarks ############"); + console.log('############ Benchmarks ############'); var sequencer = ImageSequencer({ ui: false, inBrowser: false }); var mods = Object.keys(sequencer.modules); sequencer.loadImages(image); - while ((mods[0] === 'import-image' || (!!sequencer.modulesInfo(mods[0]).requires && sequencer.modulesInfo(mods[0]).requires.includes("webgl")))) + while ((mods[0] === 'import-image' || (!!sequencer.modulesInfo(mods[0]).requires && sequencer.modulesInfo(mods[0]).requires.includes('webgl')))) mods.splice(0, 1); sequencer.addSteps(mods[0]); - global.start = Date.now() - global.idx = 0 + global.start = Date.now(); + global.idx = 0; sequencer.run(cb); function cb() { var end = Date.now(); - console.log("Module " + mods[0] + " ran in: " + (end - global.start) + " milliseconds"); + console.log('Module ' + mods[0] + ' ran in: ' + (end - global.start) + ' milliseconds'); mods.splice(0, 1); if (mods.length > 1) { //Last one is test module, we need not benchmark it sequencer.steps[global.idx].output.src = image; global.idx++; - if (mods[0] === 'import-image' || (!!sequencer.modulesInfo(mods[0]).requires && sequencer.modulesInfo(mods[0]).requires.includes("webgl"))) { + if (mods[0] === 'import-image' || (!!sequencer.modulesInfo(mods[0]).requires && sequencer.modulesInfo(mods[0]).requires.includes('webgl'))) { /* Not currently working */ - console.log("Bypassing import-image"); + console.log('Bypassing import-image'); mods.splice(0, 1); } sequencer.addSteps(mods[0]); global.start = Date.now(); sequencer.run({ index: global.idx }, cb); } else { - console.log("####################################"); + console.log('####################################'); t.end(); } } diff --git a/test/core/sequencer/chain.js b/test/core/sequencer/chain.js index 071a7493..6c707c72 100644 --- a/test/core/sequencer/chain.js +++ b/test/core/sequencer/chain.js @@ -9,18 +9,18 @@ var test = require('tape'); require('../../../src/ImageSequencer.js'); var sequencer = ImageSequencer({ ui: false }); -var red = ""; +var red = ''; test('loadImages/loadImage has a name generator.', function (t){ sequencer.loadImage(red); - t.equal(sequencer.steps.length, 1, "Initial Step Created"); + t.equal(sequencer.steps.length, 1, 'Initial Step Created'); t.end(); }); test('loadImages/loadImage returns a wrapper in the callback.', function (t){ sequencer.loadImage(red, function() { var returnval = this; - t.equal(returnval.name,"ImageSequencer Wrapper", "Wrapper is returned"); + t.equal(returnval.name,'ImageSequencer Wrapper', 'Wrapper is returned'); t.end(); }); }); @@ -29,18 +29,18 @@ test('addSteps is two-way chainable.', function (t){ sequencer.loadImage(red, function(){ var returnval = this; this.addSteps('invert'); - t.equal(returnval.name,"ImageSequencer Wrapper", "Wrapper is returned"); - t.equal(sequencer.steps.length,2,"Loaded image is affected"); - t.equal(sequencer.steps[1].options.name,"invert","Correct Step Added"); + t.equal(returnval.name,'ImageSequencer Wrapper', 'Wrapper is returned'); + t.equal(sequencer.steps.length,2,'Loaded image is affected'); + t.equal(sequencer.steps[1].options.name,'invert','Correct Step Added'); t.end(); }); }); test('addSteps is two-way chainable without loadImages.', function (t){ - var returnval = sequencer.addSteps("ndvi"); - t.equal(returnval.name,"ImageSequencer","Sequencer is returned"); - t.equal(sequencer.steps.length,3,"Step length increased"); - t.equal(sequencer.steps[2].options.name,"ndvi","Correct Step Added"); + var returnval = sequencer.addSteps('ndvi'); + t.equal(returnval.name,'ImageSequencer','Sequencer is returned'); + t.equal(sequencer.steps.length,3,'Step length increased'); + t.equal(sequencer.steps[2].options.name,'ndvi','Correct Step Added'); t.end(); }); @@ -49,7 +49,7 @@ test('removeSteps is two-way chainable.', function (t){ var returnval = this; this.addSteps('invert').removeSteps(1); - t.equal(returnval.name,"ImageSequencer Wrapper", "Wrapper is returned"); + t.equal(returnval.name,'ImageSequencer Wrapper', 'Wrapper is returned'); t.equal(sequencer.steps.length,3); t.end(); }); @@ -57,7 +57,7 @@ test('removeSteps is two-way chainable.', function (t){ test('removeSteps is two-way chainable without loadImages.', function (t){ var returnval = sequencer.addSteps('blur').removeSteps(3); - t.equal(returnval.name,"ImageSequencer","Sequencer is returned"); + t.equal(returnval.name,'ImageSequencer','Sequencer is returned'); t.equal(sequencer.steps.length,3); t.end(); }); @@ -66,17 +66,17 @@ test('insertSteps is two-way chainable.', function (t){ sequencer.loadImage(red,function() { var returnval = this; this.insertSteps(1,'invert'); - t.equal(returnval.name,"ImageSequencer Wrapper","Wrapper is returned"); + t.equal(returnval.name,'ImageSequencer Wrapper','Wrapper is returned'); t.equal(sequencer.steps.length,4); - t.equal(sequencer.steps[1].options.name,"invert","Correct Step Inserrted"); + t.equal(sequencer.steps[1].options.name,'invert','Correct Step Inserrted'); t.end(); }); }); test('insertSteps is two-way chainable without loadImages.', function (t){ - var returnval = sequencer.insertSteps(1,"ndvi"); - t.equal(returnval.name,"ImageSequencer","Sequencer is returned"); + var returnval = sequencer.insertSteps(1,'ndvi'); + t.equal(returnval.name,'ImageSequencer','Sequencer is returned'); t.equal(sequencer.steps.length,5); - t.equal(sequencer.steps[1].options.name,"ndvi","Correct Step Inserrted"); + t.equal(sequencer.steps[1].options.name,'ndvi','Correct Step Inserrted'); t.end(); }); diff --git a/test/core/sequencer/dynamic-imports.js b/test/core/sequencer/dynamic-imports.js index 4203bcc1..a0d5e57e 100644 --- a/test/core/sequencer/dynamic-imports.js +++ b/test/core/sequencer/dynamic-imports.js @@ -2,7 +2,7 @@ var test = require('tape'); require('../../../src/ImageSequencer.js'); var sequencer = ImageSequencer({ ui: false }); -var red = ""; +var red = ''; test('Dynamically add a test Module', function(t) { sequencer.loadNewModule('test', { func: require('../testModule/Module'), info: require('../testModule/info') }); @@ -10,7 +10,7 @@ test('Dynamically add a test Module', function(t) { t.deepEqual(sequencer.modules['test'], [ require('../testModule/Module'), require('../testModule/info') - ], "test module was succesfully imported"); + ], 'test module was succesfully imported'); sequencer.addSteps('invert'); sequencer.addSteps('test'); sequencer.addSteps('invert'); diff --git a/test/core/sequencer/image-sequencer.js b/test/core/sequencer/image-sequencer.js index 293a46b9..a7631e28 100644 --- a/test/core/sequencer/image-sequencer.js +++ b/test/core/sequencer/image-sequencer.js @@ -15,29 +15,29 @@ function copy(g, a) { var i = 0; for (var v in a) if (g) { - if (v != "sequencer") b[v] = a[v]; + if (v != 'sequencer') b[v] = a[v]; } else { - if (v != "sequencer" && v != "global1" && v != "global2" && !global1.hasOwnProperty(v)) i++; + if (v != 'sequencer' && v != 'global1' && v != 'global2' && !global1.hasOwnProperty(v)) i++; } if (g) return b; else return i; } -var parent = (typeof (global) === "undefined") ? window : global; +var parent = (typeof (global) === 'undefined') ? window : global; var global1 = copy(true, parent); var sequencer = ImageSequencer({ ui: false }); -var red = ""; +var red = ''; test('Image Sequencer has tests', function(t) { - t.equal(true, true, "Initial Test"); + t.equal(true, true, 'Initial Test'); t.end(); }); test('loadImages loads a DataURL image and creates a step.', function(t) { sequencer.loadImages(red); - t.equal(sequencer.steps.length, 1, "Initial Step Created"); - t.equal(typeof (sequencer.steps[0].output.src), "string", "Initial output exists"); + t.equal(sequencer.steps.length, 1, 'Initial Step Created'); + t.equal(typeof (sequencer.steps[0].output.src), 'string', 'Initial output exists'); t.end(); }); @@ -54,13 +54,13 @@ if (!sequencer.options.inBrowser) test('loadImage loads an image from URL and creates a step. (NodeJS)', function(t) { require('dns').resolve('www.github.com', function(err) { if (err) { - console.log("Test aborted due to no internet"); + console.log('Test aborted due to no internet'); t.end(); } else { sequencer.loadImage('URL', 'https://ccpandhare.github.io/image-sequencer/examples/images/red.jpg', function() { - t.equal(sequencer.steps.length, 1, "Initial Step Created"); - t.equal(typeof (sequencer.steps[0].output.src), "string", "Initial output exists"); + t.equal(sequencer.steps.length, 1, 'Initial Step Created'); + t.equal(typeof (sequencer.steps[0].output.src), 'string', 'Initial output exists'); t.end(); }); } @@ -70,88 +70,88 @@ if (!sequencer.options.inBrowser) if (!sequencer.options.inBrowser) test('loadImages loads an image from PATH and creates a step. (NodeJS)', function(t) { sequencer.loadImages('examples/images/red.jpg'); - t.equal(sequencer.steps.length, 1, "Initial Step Created"); - t.equal(typeof (sequencer.steps[0].output.src), "string", "Initial output exists"); + t.equal(sequencer.steps.length, 1, 'Initial Step Created'); + t.equal(typeof (sequencer.steps[0].output.src), 'string', 'Initial output exists'); t.end(); }); test('loadImage works too.', function(t) { sequencer.loadImage(red); - t.equal(sequencer.steps.length, 1, "Initial Step Created"); - t.equal(typeof (sequencer.steps[0].output.src), "string", "Initial output exists"); + t.equal(sequencer.steps.length, 1, 'Initial Step Created'); + t.equal(typeof (sequencer.steps[0].output.src), 'string', 'Initial output exists'); t.end(); }); test('addSteps("name") adds a step', function(t) { sequencer.addSteps('channel'); - t.equal(sequencer.steps.length, 2, "Length of steps increased"); - t.equal(sequencer.steps[1].options.name, "channel", "Correct Step Added"); + t.equal(sequencer.steps.length, 2, 'Length of steps increased'); + t.equal(sequencer.steps[1].options.name, 'channel', 'Correct Step Added'); t.end(); }); test('addSteps(["name"]) adds a step', function(t) { sequencer.addSteps(['channel', 'invert']); - t.equal(sequencer.steps.length, 4, "Length of steps increased by two") - t.equal(sequencer.steps[2].options.name, "channel", "Correct Step Added"); - t.equal(sequencer.steps[3].options.name, "invert", "Correct Step Added"); + t.equal(sequencer.steps.length, 4, 'Length of steps increased by two'); + t.equal(sequencer.steps[2].options.name, 'channel', 'Correct Step Added'); + t.equal(sequencer.steps[3].options.name, 'invert', 'Correct Step Added'); t.end(); }); test('addSteps("name",o) adds a step', function(t) { sequencer.addSteps('channel', {}); - t.equal(sequencer.steps.length, 5, "Length of steps increased"); - t.equal(sequencer.steps[4].options.name, "channel", "Correct Step Added"); + t.equal(sequencer.steps.length, 5, 'Length of steps increased'); + t.equal(sequencer.steps[4].options.name, 'channel', 'Correct Step Added'); t.end(); }); test('addSteps("name,name") adds two steps', function(t) { - sequencer.addSteps('channel,invert') - t.equal(sequencer.steps.length, 7, 'Length of steps increase') - t.equal(sequencer.steps[5].options.name, "channel", "Correct Step Added"); - t.equal(sequencer.steps[6].options.name, "invert", "Correct Step Added"); - t.end() -}) + sequencer.addSteps('channel,invert'); + t.equal(sequencer.steps.length, 7, 'Length of steps increase'); + t.equal(sequencer.steps[5].options.name, 'channel', 'Correct Step Added'); + t.equal(sequencer.steps[6].options.name, 'invert', 'Correct Step Added'); + t.end(); +}); test('addSteps("name{parameter:value},name{parameter:value}") adds two steps', function(t) { - sequencer.addSteps('brightness{brightness:80},average{}') - t.equal(sequencer.steps.length, 9, 'Length of steps increase') - t.equal(sequencer.steps[7].options.name, "brightness", "Correct Step Added"); - t.equal(sequencer.steps[7].options.brightness, '80', "Correct options loaded") - t.equal(sequencer.steps[8].options.name, "average", "Correct Step Added"); - t.end() -}) + sequencer.addSteps('brightness{brightness:80},average{}'); + t.equal(sequencer.steps.length, 9, 'Length of steps increase'); + t.equal(sequencer.steps[7].options.name, 'brightness', 'Correct Step Added'); + t.equal(sequencer.steps[7].options.brightness, '80', 'Correct options loaded'); + t.equal(sequencer.steps[8].options.name, 'average', 'Correct Step Added'); + t.end(); +}); test('addSteps("name{parameter:value}" adds a step', function(t) { - sequencer.addSteps('brightness{brightness:1}') - t.equal(sequencer.steps.length, 10, 'Length of steps increase') - t.equal(sequencer.steps[9].options.name, "brightness", "Correct Step Added"); - t.equal(sequencer.steps[9].options.brightness, '1', "Correct options loaded") - t.end() -}) + sequencer.addSteps('brightness{brightness:1}'); + t.equal(sequencer.steps.length, 10, 'Length of steps increase'); + t.equal(sequencer.steps[9].options.name, 'brightness', 'Correct Step Added'); + t.equal(sequencer.steps[9].options.brightness, '1', 'Correct options loaded'); + t.end(); +}); test('removeSteps(position) removes a step', function(t) { sequencer.removeSteps(1); - t.equal(sequencer.steps.length, 9, "Length of steps reduced"); + t.equal(sequencer.steps.length, 9, 'Length of steps reduced'); t.end(); }); test('removeSteps([positions]) removes steps', function(t) { sequencer.removeSteps([1, 2]); - t.equal(sequencer.steps.length, 7, "Length of steps reduced"); + t.equal(sequencer.steps.length, 7, 'Length of steps reduced'); t.end(); }); test('insertSteps(position,"module",options) inserts a step', function(t) { sequencer.insertSteps( 1, 'channel', {}); - t.equal(sequencer.steps.length, 8, "Length of Steps increased"); - t.equal(sequencer.steps[1].options.name, "channel", "Correct Step Inserted"); + t.equal(sequencer.steps.length, 8, 'Length of Steps increased'); + t.equal(sequencer.steps[1].options.name, 'channel', 'Correct Step Inserted'); t.end(); }); test('insertSteps(position,"module") inserts a step', function(t) { sequencer.insertSteps(1, 'channel'); - t.equal(sequencer.steps.length, 9, "Length of Steps increased"); - t.equal(sequencer.steps[1].options.name, "channel", "Correct Step Inserted"); + t.equal(sequencer.steps.length, 9, 'Length of Steps increased'); + t.equal(sequencer.steps[1].options.name, 'channel', 'Correct Step Inserted'); t.end(); }); @@ -162,22 +162,22 @@ test('getSteps() returns correct array of steps', function(t){ sequencer.loadImages('test', red); sequencer.addSteps(['blur','invert']); var stepsArray = sequencer.getSteps('test'); - t.equal(stepsArray.length, sequencer.steps.length, "getSteps() returns correct length of steps"); + t.equal(stepsArray.length, sequencer.steps.length, 'getSteps() returns correct length of steps'); var flag=0; for (var i = 0; i { - t.isNotEqual(out, undefined, "Opaque Meta-Module not undefined"); - t.end(); - }); + sequencer1.loadImages(red); + sequencer1.addSteps('ndvi-colormap'); + sequencer1.run((out) => { + t.isNotEqual(out, undefined, 'Opaque Meta-Module not undefined'); + t.end(); + }); }); test('Load colorbar opaque meta module', function(t) { - sequencer2.loadImages(red); - sequencer2.addSteps('colorbar'); // this has been refactored as an opaque meta-module https://github.com/publiclab/image-sequencer/issues/315 - sequencer2.run((out) => { - t.isNotEqual(out, undefined, "Opaque Meta-Module not undefined"); - t.end(); - }); + sequencer2.loadImages(red); + sequencer2.addSteps('colorbar'); // this has been refactored as an opaque meta-module https://github.com/publiclab/image-sequencer/issues/315 + sequencer2.run((out) => { + t.isNotEqual(out, undefined, 'Opaque Meta-Module not undefined'); + t.end(); + }); }); diff --git a/test/core/sequencer/replace.js b/test/core/sequencer/replace.js index 478a7b48..ebcb26a0 100644 --- a/test/core/sequencer/replace.js +++ b/test/core/sequencer/replace.js @@ -6,20 +6,20 @@ var test = require('tape'); require('../../../src/ImageSequencer.js'); var sequencer = ImageSequencer({ ui: false }); -var red = ""; +var red = ''; -if(typeof(window) !== "undefined") { - var image = document.createElement("img"); - image.src = red; - document.body.appendChild(image); +if(typeof(window) !== 'undefined') { + var image = document.createElement('img'); + image.src = red; + document.body.appendChild(image); } test('replaceImage works.', function (t){ - if (typeof(window) === "undefined") - t.end(); + if (typeof(window) === 'undefined') + t.end(); - sequencer.replaceImage("img","invert",{ callback: function(){ - t.equal(0,0, "replaceImage works"); - t.end(); - } }); + sequencer.replaceImage('img','invert',{ callback: function(){ + t.equal(0,0, 'replaceImage works'); + t.end(); + } }); }); diff --git a/test/core/sequencer/run.js b/test/core/sequencer/run.js index a1f91adc..b439ba8e 100644 --- a/test/core/sequencer/run.js +++ b/test/core/sequencer/run.js @@ -7,7 +7,7 @@ var DataURItoBuffer = require('data-uri-to-buffer'); require('../../../src/ImageSequencer.js'); var sequencer = ImageSequencer({ ui: false }); -var red = ""; +var red = ''; sequencer.loadImages(red); sequencer.addSteps('invert'); @@ -15,15 +15,15 @@ sequencer.addSteps('invert'); sequencer.addSteps('invert'); test('run() works with all possible argument combinations',function(t){ - sequencer.run(function (out) { - var output1 = DataURItoBuffer(sequencer.steps.slice(-1)[0].output.src); - sequencer.steps.splice(1,1); - sequencer.run({index: 1},function(out){ - var output2 = DataURItoBuffer(sequencer.steps.slice(-1)[0].output.src); - t.deepEqual(output1,output2,"output remains same after removing a step and running sequencer from a greater index"); - sequencer.run(function(out){ - t.end(); - }) - }); + sequencer.run(function (out) { + var output1 = DataURItoBuffer(sequencer.steps.slice(-1)[0].output.src); + sequencer.steps.splice(1,1); + sequencer.run({index: 1},function(out){ + var output2 = DataURItoBuffer(sequencer.steps.slice(-1)[0].output.src); + t.deepEqual(output1,output2,'output remains same after removing a step and running sequencer from a greater index'); + sequencer.run(function(out){ + t.end(); + }); }); + }); }); \ No newline at end of file diff --git a/test/core/templates/module-test.js b/test/core/templates/module-test.js index de0f293f..a84edc23 100644 --- a/test/core/templates/module-test.js +++ b/test/core/templates/module-test.js @@ -2,10 +2,10 @@ const test = require('tape'), base64Img = require('base64-img'), looksSame = require('looks-same'); -const ImageSequencer = require('../../../src/ImageSequencer') +const ImageSequencer = require('../../../src/ImageSequencer'); -const red = "" - target = 'test_outputs'; +const red = ''; +target = 'test_outputs'; /** * @method moduleTest @@ -16,43 +16,43 @@ const red = " * @param {String} [input="red_image"] optional input image. Default is a red image. */ module.exports = (moduleName, options, benchmark, input) => { - let sequencer = ImageSequencer({ui: false}) + let sequencer = ImageSequencer({ui: false}); test(`${moduleName} module loads correctly`, t => { - sequencer.loadImages(input || red) - sequencer.addSteps(moduleName, options) + sequencer.loadImages(input || red); + sequencer.addSteps(moduleName, options); - t.equal(sequencer.steps[1].options.name, moduleName, `${moduleName} module is getting loaded`) - t.end() - }) + t.equal(sequencer.steps[1].options.name, moduleName, `${moduleName} module is getting loaded`); + t.end(); + }); test(`${moduleName} module loads with correct options`, t => { for (const option in options) { - t.equal(sequencer.steps[1].options[option], options[option], `Option ${option} is correct`) + t.equal(sequencer.steps[1].options[option], options[option], `Option ${option} is correct`); } t.end(); - }) + }); test(`${moduleName} module works correctly`, t => { sequencer.run({mode: 'test'}, () => { - let result = sequencer.steps[1].output.src + let result = sequencer.steps[1].output.src; - base64Img.imgSync(result, target, 'result') - base64Img.imgSync(benchmark, target, 'benchmark') + base64Img.imgSync(result, target, 'result'); + base64Img.imgSync(benchmark, target, 'benchmark'); - result = './test_outputs/result.png' - benchmark = './test_outputs/benchmark.png' + result = './test_outputs/result.png'; + benchmark = './test_outputs/benchmark.png'; looksSame(result, benchmark, function(err, res) { - if (err) console.log(err) + if (err) console.log(err); - t.equal(res.equal, true, `${moduleName} module works correctly`) - sequencer = null - t.end() - }) - }) - }) + t.equal(res.equal, true, `${moduleName} module works correctly`); + sequencer = null; + t.end(); + }); + }); + }); -} \ No newline at end of file +}; \ No newline at end of file diff --git a/test/core/testModule/Module.js b/test/core/testModule/Module.js index 3482ab02..7ce83080 100644 --- a/test/core/testModule/Module.js +++ b/test/core/testModule/Module.js @@ -8,15 +8,15 @@ module.exports = function Dynamic(options, UI, util) { var step = this; - if (this.getPreviousStep().options.name != "invert") throw new Error("getPreviousStep not working"); - if (this.getNextStep().options.name != "invert") throw new Error("getNextStep not working"); - if (this.getInput(0) != this.getOutput(-1)) throw new Error("getInput and getOuput now working") - if (this.getFormat() != "jpeg") throw new Error("getFormat not working"); - if (this.getOptions().name != "test") throw new Error("getOptions not working"); - this.setOptions({ name: "test-1" }); - if (this.getOptions().name != "test-1") throw new Error("setOptions not working not working"); - this.getHeight(((h) => { if (h != 16) throw new Error("getHeight not working") })); - this.getWidth((w) => { if (w != 16) throw new Error("getWidth not working") }); + if (this.getPreviousStep().options.name != 'invert') throw new Error('getPreviousStep not working'); + if (this.getNextStep().options.name != 'invert') throw new Error('getNextStep not working'); + if (this.getInput(0) != this.getOutput(-1)) throw new Error('getInput and getOuput now working'); + if (this.getFormat() != 'jpeg') throw new Error('getFormat not working'); + if (this.getOptions().name != 'test') throw new Error('getOptions not working'); + this.setOptions({ name: 'test-1' }); + if (this.getOptions().name != 'test-1') throw new Error('setOptions not working not working'); + this.getHeight(((h) => { if (h != 16) throw new Error('getHeight not working'); })); + this.getWidth((w) => { if (w != 16) throw new Error('getWidth not working'); }); function output(image, datauri, mimetype) { step.output = input; @@ -29,5 +29,5 @@ module.exports = function Dynamic(options, UI, util) { draw: draw, output: output, UI: UI - } -} \ No newline at end of file + }; +}; \ No newline at end of file diff --git a/test/core/ui/user-interface.js b/test/core/ui/user-interface.js index 5dbfad24..bc067860 100644 --- a/test/core/ui/user-interface.js +++ b/test/core/ui/user-interface.js @@ -2,30 +2,30 @@ var test = require('tape'); var jsdom = require('jsdom'); var JSDOM = jsdom.JSDOM; -var DOM = new JSDOM(``); +var DOM = new JSDOM(''); global.document = DOM.window.document; -var DefaultHtmlStepUi = require('../../../examples/lib/defaultHtmlStepUi') +var DefaultHtmlStepUi = require('../../../examples/lib/defaultHtmlStepUi'); var sequencer = require('../../../src/ImageSequencer.js')(); var UserInterface = require('../../../src/ui/UserInterface'); test('Notify function works for all three UIs', function (t) { - //Mocking console.log for testing default notify() - function doesLogMessage(f, message) { - var oldLog = console.log, - result = false; - console.log = function (s) { - if (s == message) { - result = true; - } - }; - f('Test Message'); - console.log = oldLog; - return result; - } - t.equal(doesLogMessage(UserInterface().notify, 'Test Message'),true,'Default notify() produces correct output'); - sequencer.setUI(DefaultHtmlStepUi(sequencer)); - t.equal(typeof sequencer.events.notify, "function", "Html UI contains notify function"); - t.end(); + //Mocking console.log for testing default notify() + function doesLogMessage(f, message) { + var oldLog = console.log, + result = false; + console.log = function (s) { + if (s == message) { + result = true; + } + }; + f('Test Message'); + console.log = oldLog; + return result; + } + t.equal(doesLogMessage(UserInterface().notify, 'Test Message'),true,'Default notify() produces correct output'); + sequencer.setUI(DefaultHtmlStepUi(sequencer)); + t.equal(typeof sequencer.events.notify, 'function', 'Html UI contains notify function'); + t.end(); }); diff --git a/test/core/util/gpuUtils.js b/test/core/util/gpuUtils.js index 5b8e09c9..0bd8b5b3 100644 --- a/test/core/util/gpuUtils.js +++ b/test/core/util/gpuUtils.js @@ -1,96 +1,96 @@ const test = require('tape'); -const { convolve, compute } = require('../../../src/modules/_nomodule/gpuUtils') +const { convolve, compute } = require('../../../src/modules/_nomodule/gpuUtils'); test('convolve works with 1x1 array', t => { const array = [[1]], - kernel = [ - [1, 1, 1], - [1, 1, 1], - [1, 1, 1] - ], - expectedOut = [ - [9] - ] + kernel = [ + [1, 1, 1], + [1, 1, 1], + [1, 1, 1] + ], + expectedOut = [ + [9] + ]; const out = convolve([array], kernel); - t.equal(out.length, 1, 'convolve returns a single output array') - t.equal(out[0][0].length, 1, 'ouput array width is correct') - t.equal(out[0].length, 1, 'ouput array height is correct') - t.deepEqual(out[0], expectedOut, 'convolve outputs correct array') - t.end() -}) + t.equal(out.length, 1, 'convolve returns a single output array'); + t.equal(out[0][0].length, 1, 'ouput array width is correct'); + t.equal(out[0].length, 1, 'ouput array height is correct'); + t.deepEqual(out[0], expectedOut, 'convolve outputs correct array'); + t.end(); +}); test('convolve works with 3x4 array', t => { const array = [ - [1, 2, 3], - [1, 2, 4], - [1, 3, 3], - [1, 2, 3] - ], - kernel = [ - [1, 1, 1], - [1, 1, 1], - [1, 1, 1] - ], - expectedOut = [ - [12, 19, 26], - [13, 20, 27], - [13, 20, 27], - [13, 19, 25] - ] + [1, 2, 3], + [1, 2, 4], + [1, 3, 3], + [1, 2, 3] + ], + kernel = [ + [1, 1, 1], + [1, 1, 1], + [1, 1, 1] + ], + expectedOut = [ + [12, 19, 26], + [13, 20, 27], + [13, 20, 27], + [13, 19, 25] + ]; const out = convolve([array], kernel); - t.equal(out.length, 1, 'convolve returns a single output array') - t.equal(out[0][0].length, 3, 'ouput array width is correct') - t.equal(out[0].length, 4, 'ouput array height is correct') - t.deepEqual(out[0], expectedOut, 'convolve outputs correct array') - t.end() -}) + t.equal(out.length, 1, 'convolve returns a single output array'); + t.equal(out[0][0].length, 3, 'ouput array width is correct'); + t.equal(out[0].length, 4, 'ouput array height is correct'); + t.deepEqual(out[0], expectedOut, 'convolve outputs correct array'); + t.end(); +}); test('convolve works with multiple 3x4 arrays', t => { const array1 = [ - [1, 2, 3], - [1, 2, 4], - [1, 3, 3], - [1, 2, 3] - ], - array2 = [ - [1, 2, 4], - [2, 2, 1], - [1, 0, 0], - [2, 3, 1] - ], - kernel = [ - [1, 1, 1], - [1, 1, 1], - [1, 1, 1] - ], - expectedOut1 = [ - [12, 19, 26], - [13, 20, 27], - [13, 20, 27], - [13, 19, 25] - ], - expectedOut2 = [ - [14, 19, 24], - [12, 13, 14], - [15, 12, 9], - [16, 13, 10] - ] + [1, 2, 3], + [1, 2, 4], + [1, 3, 3], + [1, 2, 3] + ], + array2 = [ + [1, 2, 4], + [2, 2, 1], + [1, 0, 0], + [2, 3, 1] + ], + kernel = [ + [1, 1, 1], + [1, 1, 1], + [1, 1, 1] + ], + expectedOut1 = [ + [12, 19, 26], + [13, 20, 27], + [13, 20, 27], + [13, 19, 25] + ], + expectedOut2 = [ + [14, 19, 24], + [12, 13, 14], + [15, 12, 9], + [16, 13, 10] + ]; const out = convolve([array1, array2], kernel); - t.equal(out.length, 2, 'convolve returns 2 output array') + t.equal(out.length, 2, 'convolve returns 2 output array'); - t.equal(out[0][0].length, 3, 'ouput array1 width is correct') - t.equal(out[0].length, 4, 'ouput array1 height is correct') + t.equal(out[0][0].length, 3, 'ouput array1 width is correct'); + t.equal(out[0].length, 4, 'ouput array1 height is correct'); - t.equal(out[1][0].length, 3, 'ouput array2 width is correct') - t.equal(out[1].length, 4, 'ouput array2 height is correct') + t.equal(out[1][0].length, 3, 'ouput array2 width is correct'); + t.equal(out[1].length, 4, 'ouput array2 height is correct'); - t.deepEqual(out[0], expectedOut1, 'convolve outputs correct array1') - t.deepEqual(out[1], expectedOut2, 'convolve outputs correct array2') - t.end() -}) \ No newline at end of file + t.deepEqual(out[0], expectedOut1, 'convolve outputs correct array1'); + t.deepEqual(out[1], expectedOut2, 'convolve outputs correct array2'); + t.end(); +}); \ No newline at end of file diff --git a/test/core/util/parse-input.js b/test/core/util/parse-input.js index 0a2e8bf4..f8560ab8 100644 --- a/test/core/util/parse-input.js +++ b/test/core/util/parse-input.js @@ -1,17 +1,17 @@ var test = require('tape'); -var red = ""; +var red = ''; var parseCornerCoordinateInputs = require('../../../src/util/ParseInputCoordinates'); test('parseCornerCoordinateInputs works.', function (t) { - var options = { x: '10%' }, - coord = { src: red, x: { valInp: options.x, type: 'horizontal' } } - callback = function (options, coord) { - options.x = parseInt(coord.x.valInp); - t.equal(options.x, 1, 'parseCornerCoordinateInputs works.'); - t.end(); - }; - parseCornerCoordinateInputs(options, coord, callback); + var options = { x: '10%' }, + coord = { src: red, x: { valInp: options.x, type: 'horizontal' } }; + callback = function (options, coord) { + options.x = parseInt(coord.x.valInp); + t.equal(options.x, 1, 'parseCornerCoordinateInputs works.'); + t.end(); + }; + parseCornerCoordinateInputs(options, coord, callback); }); diff --git a/test/spec/defaultHtmlSequencerUi.spec.js b/test/spec/defaultHtmlSequencerUi.spec.js index a3701457..ec295589 100644 --- a/test/spec/defaultHtmlSequencerUi.spec.js +++ b/test/spec/defaultHtmlSequencerUi.spec.js @@ -1,42 +1,42 @@ describe('Default sequencer HTML', function() { - var DefaultHtmlSequencerUi = require('../../examples/lib/defaultHtmlSequencerUi') - var sequencer = require('../../src/ImageSequencer')() + var DefaultHtmlSequencerUi = require('../../examples/lib/defaultHtmlSequencerUi'); + var sequencer = require('../../src/ImageSequencer')(); var defaultHtmlSequencerUi; beforeEach(()=>{ - defaultHtmlSequencerUi = new DefaultHtmlSequencerUi(sequencer) + defaultHtmlSequencerUi = new DefaultHtmlSequencerUi(sequencer); - spyOn(defaultHtmlSequencerUi,'onLoad') - spyOn(defaultHtmlSequencerUi,'selectNewStepUi') - spyOn(defaultHtmlSequencerUi,'removeStepUi') - spyOn(defaultHtmlSequencerUi,'addStepUi') - spyOn(defaultHtmlSequencerUi,'importStepsFromUrlHash') + spyOn(defaultHtmlSequencerUi,'onLoad'); + spyOn(defaultHtmlSequencerUi,'selectNewStepUi'); + spyOn(defaultHtmlSequencerUi,'removeStepUi'); + spyOn(defaultHtmlSequencerUi,'addStepUi'); + spyOn(defaultHtmlSequencerUi,'importStepsFromUrlHash'); - defaultHtmlSequencerUi.onLoad() - defaultHtmlSequencerUi.selectNewStepUi() - defaultHtmlSequencerUi.addStepUi() - defaultHtmlSequencerUi.removeStepUi() - defaultHtmlSequencerUi.importStepsFromUrlHash() - }) + defaultHtmlSequencerUi.onLoad(); + defaultHtmlSequencerUi.selectNewStepUi(); + defaultHtmlSequencerUi.addStepUi(); + defaultHtmlSequencerUi.removeStepUi(); + defaultHtmlSequencerUi.importStepsFromUrlHash(); + }); it('load default ui', function() { - expect(defaultHtmlSequencerUi.onLoad).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.onLoad).toHaveBeenCalled(); + }); it('select step ui', function() { - expect(defaultHtmlSequencerUi.selectNewStepUi).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.selectNewStepUi).toHaveBeenCalled(); + }); it('add step ui', function() { - expect(defaultHtmlSequencerUi.addStepUi).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.addStepUi).toHaveBeenCalled(); + }); it('remove step ui', function() { - expect(defaultHtmlSequencerUi.removeStepUi).toHaveBeenCalled() - }) + expect(defaultHtmlSequencerUi.removeStepUi).toHaveBeenCalled(); + }); it('import options from url', function() { - expect(defaultHtmlSequencerUi.importStepsFromUrlHash).toHaveBeenCalled() - }) -}) \ No newline at end of file + expect(defaultHtmlSequencerUi.importStepsFromUrlHash).toHaveBeenCalled(); + }); +}); \ No newline at end of file diff --git a/test/spec/defaultHtmlStepUi.spec.js b/test/spec/defaultHtmlStepUi.spec.js index d237c6f9..63336562 100644 --- a/test/spec/defaultHtmlStepUi.spec.js +++ b/test/spec/defaultHtmlStepUi.spec.js @@ -1,61 +1,61 @@ var { JSDOM } = require('jsdom'); -var DOM = new JSDOM(``); +var DOM = new JSDOM(''); global.document = DOM.window.document; describe('Sequencer step HTML', function() { - var DefaultHtmlStepUi = require('../../examples/lib/defaultHtmlStepUi') - var sequencer = require('../../src/ImageSequencer')() + var DefaultHtmlStepUi = require('../../examples/lib/defaultHtmlStepUi'); + var sequencer = require('../../src/ImageSequencer')(); var defaultHtmlStepUi; - var step = 'brightness' + var step = 'brightness'; var options = { - name: "Brightness", - description: "Change the brightness of the image by given percent value" - } + name: 'Brightness', + description: 'Change the brightness of the image by given percent value' + }; // options = JSON.parse(options) beforeEach(()=>{ - defaultHtmlStepUi = new DefaultHtmlStepUi(sequencer) + defaultHtmlStepUi = new DefaultHtmlStepUi(sequencer); - spyOn(defaultHtmlStepUi,'getPreview') - spyOn(defaultHtmlStepUi,'onSetup') - spyOn(defaultHtmlStepUi,'onComplete') - spyOn(defaultHtmlStepUi,'onDraw') - spyOn(defaultHtmlStepUi,'onRemove') - spyOn(defaultHtmlStepUi,'notify') + spyOn(defaultHtmlStepUi,'getPreview'); + spyOn(defaultHtmlStepUi,'onSetup'); + spyOn(defaultHtmlStepUi,'onComplete'); + spyOn(defaultHtmlStepUi,'onDraw'); + spyOn(defaultHtmlStepUi,'onRemove'); + spyOn(defaultHtmlStepUi,'notify'); - defaultHtmlStepUi.getPreview() - defaultHtmlStepUi.onSetup(step,options) - defaultHtmlStepUi.onComplete(step) - defaultHtmlStepUi.onDraw(step) - defaultHtmlStepUi.onRemove(step) - defaultHtmlStepUi.notify('Step removed','remove-notification') - }) + defaultHtmlStepUi.getPreview(); + defaultHtmlStepUi.onSetup(step,options); + defaultHtmlStepUi.onComplete(step); + defaultHtmlStepUi.onDraw(step); + defaultHtmlStepUi.onRemove(step); + defaultHtmlStepUi.notify('Step removed','remove-notification'); + }); it('result preview ui', function() { - expect(defaultHtmlStepUi.getPreview).toHaveBeenCalled() - }) + expect(defaultHtmlStepUi.getPreview).toHaveBeenCalled(); + }); it('load initial setup ui', function() { - expect(defaultHtmlStepUi.onSetup).toHaveBeenCalledWith(step,options) - }) + expect(defaultHtmlStepUi.onSetup).toHaveBeenCalledWith(step,options); + }); it('load completion ui', function() { - expect(defaultHtmlStepUi.onComplete).toHaveBeenCalledWith(step) - }) + expect(defaultHtmlStepUi.onComplete).toHaveBeenCalledWith(step); + }); it('draw step ui', function() { - expect(defaultHtmlStepUi.onDraw).toHaveBeenCalledWith(step) - }) + expect(defaultHtmlStepUi.onDraw).toHaveBeenCalledWith(step); + }); it('remove step ui', function() { - expect(defaultHtmlStepUi.onRemove).toHaveBeenCalledWith(step) - }) + expect(defaultHtmlStepUi.onRemove).toHaveBeenCalledWith(step); + }); it('notification ui', function() { - expect(defaultHtmlStepUi.notify).toHaveBeenCalledWith('Step removed','remove-notification') - }) + expect(defaultHtmlStepUi.notify).toHaveBeenCalledWith('Step removed','remove-notification'); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/test/spec/insertPreview.spec.js b/test/spec/insertPreview.spec.js index db1fa16f..20702443 100644 --- a/test/spec/insertPreview.spec.js +++ b/test/spec/insertPreview.spec.js @@ -1,26 +1,26 @@ describe('Preview UI HTML', function() { - var InsertPreview = require('../../examples/lib/insertPreview') - var sequencer = require('../../src/ImageSequencer')() + var InsertPreview = require('../../examples/lib/insertPreview'); + var sequencer = require('../../src/ImageSequencer')(); var insertPreview; - var options = { brightness: 50 } + var options = { brightness: 50 }; beforeEach(()=>{ - insertPreview = InsertPreview + insertPreview = InsertPreview; - spyOn(insertPreview,'generatePreview') - spyOn(insertPreview,'updatePreviews') + spyOn(insertPreview,'generatePreview'); + spyOn(insertPreview,'updatePreviews'); - insertPreview.generatePreview('brightness',options,'src','selector') - insertPreview.updatePreviews('src','selector') - }) + insertPreview.generatePreview('brightness',options,'src','selector'); + insertPreview.updatePreviews('src','selector'); + }); it('generate preview ui', function() { - expect(insertPreview.generatePreview).toHaveBeenCalledWith('brightness',options,'src','selector') - }) + expect(insertPreview.generatePreview).toHaveBeenCalledWith('brightness',options,'src','selector'); + }); it('update preview ui', function() { - expect(insertPreview.updatePreviews).toHaveBeenCalledWith('src','selector') - }) + expect(insertPreview.updatePreviews).toHaveBeenCalledWith('src','selector'); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/test/spec/intermediateHtmlStepUi.spec.js b/test/spec/intermediateHtmlStepUi.spec.js index c27c3a45..94381a88 100644 --- a/test/spec/intermediateHtmlStepUi.spec.js +++ b/test/spec/intermediateHtmlStepUi.spec.js @@ -1,19 +1,19 @@ describe('Intermediate step HTML', function() { - var IntermediateHtmlStepUi = require('../../examples/lib/intermediateHtmlStepUi') - var sequencer = require('../../src/ImageSequencer')() + var IntermediateHtmlStepUi = require('../../examples/lib/intermediateHtmlStepUi'); + var sequencer = require('../../src/ImageSequencer')(); var intermediateHtmlStepUi; beforeEach(()=>{ - intermediateHtmlStepUi = new IntermediateHtmlStepUi(sequencer) + intermediateHtmlStepUi = new IntermediateHtmlStepUi(sequencer); - spyOn(intermediateHtmlStepUi,'insertStep') + spyOn(intermediateHtmlStepUi,'insertStep'); - intermediateHtmlStepUi.insertStep() - }) + intermediateHtmlStepUi.insertStep(); + }); it('insert step ui', function() { - expect(intermediateHtmlStepUi.insertStep).toHaveBeenCalled() - }) + expect(intermediateHtmlStepUi.insertStep).toHaveBeenCalled(); + }); -}) \ No newline at end of file +}); \ No newline at end of file diff --git a/test/spec/urlHash.spec.js b/test/spec/urlHash.spec.js index f3f21b67..09a7967e 100644 --- a/test/spec/urlHash.spec.js +++ b/test/spec/urlHash.spec.js @@ -1,40 +1,40 @@ describe('URL manipulation methods', function() { - var UrlHash = require('../../examples/lib/urlHash') + var UrlHash = require('../../examples/lib/urlHash'); var urlHash; var params = { module: 'brightness', brightness: 50 - } + }; beforeEach(()=>{ - urlHash = UrlHash + urlHash = UrlHash; - spyOn(urlHash,'getUrlHashParameters') - spyOn(urlHash,'getUrlHashParameter') - spyOn(urlHash,'setUrlHashParameters') - spyOn(urlHash,'setUrlHashParameter') + spyOn(urlHash,'getUrlHashParameters'); + spyOn(urlHash,'getUrlHashParameter'); + spyOn(urlHash,'setUrlHashParameters'); + spyOn(urlHash,'setUrlHashParameter'); - urlHash.getUrlHashParameters() - urlHash.getUrlHashParameter('module') - urlHash.setUrlHashParameters(params) - urlHash.setUrlHashParameter('module','brightness') - }) + urlHash.getUrlHashParameters(); + urlHash.getUrlHashParameter('module'); + urlHash.setUrlHashParameters(params); + urlHash.setUrlHashParameter('module','brightness'); + }); it('gets url hash params from window hash', function() { - expect(urlHash.getUrlHashParameters).toHaveBeenCalled() - }) + expect(urlHash.getUrlHashParameters).toHaveBeenCalled(); + }); it('gets url hash param from params object', function() { - expect(urlHash.getUrlHashParameter).toHaveBeenCalledWith('module') - }) + expect(urlHash.getUrlHashParameter).toHaveBeenCalledWith('module'); + }); it('accepts param object and sets url hash params', function() { - expect(urlHash.setUrlHashParameters).toHaveBeenCalledWith(params) - }) + expect(urlHash.setUrlHashParameters).toHaveBeenCalledWith(params); + }); it('accepts param key-value pair and sets url hash params', function() { - expect(urlHash.setUrlHashParameter).toHaveBeenCalledWith('module','brightness') - }) + expect(urlHash.setUrlHashParameter).toHaveBeenCalledWith('module','brightness'); + }); -}) \ No newline at end of file +}); \ No newline at end of file