diff --git a/public/assets/images/cover/git.jpg b/public/assets/images/cover/git.jpg
new file mode 100644
index 0000000..3dfefbb
Binary files /dev/null and b/public/assets/images/cover/git.jpg differ
diff --git a/public/assets/images/cover/gulp.jpg b/public/assets/images/cover/gulp.jpg
new file mode 100644
index 0000000..98433b6
Binary files /dev/null and b/public/assets/images/cover/gulp.jpg differ
diff --git a/public/assets/images/cover/gulp.svg b/public/assets/images/cover/gulp.svg
deleted file mode 100644
index fa73fe9..0000000
--- a/public/assets/images/cover/gulp.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/src/content/journal/2009/git.mdx b/src/content/journal/2009/git.mdx
index f9c600a..e9690eb 100644
--- a/src/content/journal/2009/git.mdx
+++ b/src/content/journal/2009/git.mdx
@@ -4,7 +4,7 @@ slug: git
author: Stefan Imhoff
date: 2009-02-10T20:00:00+02:00
description: An extensive collection of links to tutorials, tutorials, screencasts, and documentation on Git.
-cover: /assets/images/cover/git.svg
+cover: /assets/images/cover/git.jpg
tags: ["code"]
---
diff --git a/src/content/journal/2014/gulp-tutorial-1-intro-setup.mdx b/src/content/journal/2014/gulp-tutorial-1-intro-setup.mdx
index 923f76d..ff4e27c 100644
--- a/src/content/journal/2014/gulp-tutorial-1-intro-setup.mdx
+++ b/src/content/journal/2014/gulp-tutorial-1-intro-setup.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-1-intro-setup
author: Stefan Imhoff
date: 2014-10-18T08:35:47+02:00
description: "The ultimate tutorial and guide for Gulp.js: The first part of my series on Gulp.js. What is Gulp.js? Why use it? And how to install Gulp and Jekyll."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -60,10 +60,10 @@ You may use the installation helper by typing the command `npm init`. But I find
```json
{
- "name": "gulp-build",
- "version": "0.0.1",
- "description": "The build process of my website with Gulp.js",
- "private": true
+ "name": "gulp-build",
+ "version": "0.0.1",
+ "description": "The build process of my website with Gulp.js",
+ "private": true
}
```
@@ -143,5 +143,5 @@ Did you install it globally? Then drop the `bundle exec` from the command.
This concludes the 1st part of my series _Introduction to Gulp.js_. We learned what Gulp.js is used for and created the basic folder structure for the project.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-10-generating-sprites.mdx b/src/content/journal/2014/gulp-tutorial-10-generating-sprites.mdx
index be1c818..ef5cb58 100644
--- a/src/content/journal/2014/gulp-tutorial-10-generating-sprites.mdx
+++ b/src/content/journal/2014/gulp-tutorial-10-generating-sprites.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-10-generating-sprites
author: Stefan Imhoff
date: 2014-10-27T07:40:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to generate image sprite maps with Spritesmith."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -63,11 +63,11 @@ var config = require("../../config").sprites;
* Generate sprite and CSS files from PNGs
*/
gulp.task("sprites", function () {
- var spriteData = gulp.src(config.src).pipe(spritesmith(config.options));
+ var spriteData = gulp.src(config.src).pipe(spritesmith(config.options));
- spriteData.img.pipe(gulp.dest(config.dest.image));
+ spriteData.img.pipe(gulp.dest(config.dest.image));
- spriteData.css.pipe(gulp.dest(config.dest.css));
+ spriteData.css.pipe(gulp.dest(config.dest.css));
});
```
@@ -82,5 +82,5 @@ Next, I will write the tasks needed to get a production-ready code.
This concludes the 10th part of my series, _Introduction to Gulp.js_. Today, we learned how to create CSS image sprites with Gulp.js and Spritesmith.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-11-production-build-server-and-jekyll.mdx b/src/content/journal/2014/gulp-tutorial-11-production-build-server-and-jekyll.mdx
index 11b420a..7bd5677 100644
--- a/src/content/journal/2014/gulp-tutorial-11-production-build-server-and-jekyll.mdx
+++ b/src/content/journal/2014/gulp-tutorial-11-production-build-server-and-jekyll.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-11-production-build-server-and-jekyll
author: Stefan Imhoff
date: 2014-10-28T07:30:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to write the production task for Jekyll and BrowserSync."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -61,7 +61,7 @@ var config = require("../../config").browsersync.production;
* Start a server and watch changes with BrowserSync
*/
gulp.task("browsersync:production", ["build:production"], function () {
- browsersync(config);
+ browsersync(config);
});
```
@@ -79,16 +79,16 @@ var runSequence = require("run-sequence");
* Run all tasks needed for a build in the defined order
*/
gulp.task("build:production", function (callback) {
- runSequence(
- "delete",
- "jekyll:production",
- ["sass", "scripts", "images", "copy:fonts"],
- "base64",
- ["optimize:css", "optimize:js", "optimize:images", "optimize:html", "copy:fonts:production"],
- "revision",
- "rev:collect",
- callback
- );
+ runSequence(
+ "delete",
+ "jekyll:production",
+ ["sass", "scripts", "images", "copy:fonts"],
+ "base64",
+ ["optimize:css", "optimize:js", "optimize:images", "optimize:html", "copy:fonts:production"],
+ "revision",
+ "rev:collect",
+ callback
+ );
});
```
@@ -135,23 +135,23 @@ var config = require("../../config").jekyll.production;
* Build the Jekyll Site
*/
gulp.task("jekyll:production", function (done) {
- browsersync.notify("Compiling Jekyll (Production)");
+ browsersync.notify("Compiling Jekyll (Production)");
- return cp
- .spawn(
- "bundle",
- [
- "exec",
- "jekyll",
- "build",
- "-q",
- "--source=" + config.src,
- "--destination=" + config.dest,
- "--config=" + config.config,
- ],
- { stdio: "inherit" }
- )
- .on("close", done);
+ return cp
+ .spawn(
+ "bundle",
+ [
+ "exec",
+ "jekyll",
+ "build",
+ "-q",
+ "--source=" + config.src,
+ "--destination=" + config.dest,
+ "--config=" + config.config,
+ ],
+ { stdio: "inherit" }
+ )
+ .on("close", done);
});
```
@@ -160,5 +160,5 @@ gulp.task("jekyll:production", function (done) {
This concludes the 11th part of my series _Introduction to Gulp.js_. Today, I started to work on the production part of my website, including a server to view the production site and generate a production build of my Jekyll site.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-12-optimize-css-javascript-images-and-html.mdx b/src/content/journal/2014/gulp-tutorial-12-optimize-css-javascript-images-and-html.mdx
index a539ad9..0077b88 100644
--- a/src/content/journal/2014/gulp-tutorial-12-optimize-css-javascript-images-and-html.mdx
+++ b/src/content/journal/2014/gulp-tutorial-12-optimize-css-javascript-images-and-html.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-12-optimize-css-javascript-images-and-html
author: Stefan Imhoff
date: 2014-10-29T08:00:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to optimize CSS, JavaScript, images, and HTML to speed up your website."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -47,7 +47,7 @@ var config = require("../../config").optimize.css;
* Copy and minimize CSS files
*/
gulp.task("optimize:css", function () {
- return gulp.src(config.src).pipe(csso(config.options)).pipe(gulp.dest(config.dest)).pipe(size());
+ return gulp.src(config.src).pipe(csso(config.options)).pipe(gulp.dest(config.dest)).pipe(size());
});
```
@@ -88,11 +88,11 @@ var config = require("../../config").optimize.js;
* Copy and minimize JS files
*/
gulp.task("optimize:js", function () {
- return gulp
- .src(config.src)
- .pipe(uglify(config.options))
- .pipe(gulp.dest(config.dest))
- .pipe(size());
+ return gulp
+ .src(config.src)
+ .pipe(uglify(config.options))
+ .pipe(gulp.dest(config.dest))
+ .pipe(size());
});
```
@@ -150,11 +150,11 @@ var config = require("../../config").optimize.images;
* Copy and minimize image files
*/
gulp.task("optimize:images", function () {
- return gulp
- .src(config.src)
- .pipe(imagemin(config.options))
- .pipe(gulp.dest(config.dest))
- .pipe(size());
+ return gulp
+ .src(config.src)
+ .pipe(imagemin(config.options))
+ .pipe(gulp.dest(config.dest))
+ .pipe(size());
});
```
@@ -202,7 +202,7 @@ var config = require("../../config").optimize.html;
* Minimize HTML
*/
gulp.task("optimize:html", function () {
- return gulp.src(config.src).pipe(htmlmin(config.options)).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(htmlmin(config.options)).pipe(gulp.dest(config.dest));
});
```
@@ -211,5 +211,5 @@ gulp.task("optimize:html", function () {
This concludes the 12th part of my series _Introduction to Gulp.js_. Today we learned how to minimize CSS and JavaScript files and reduce the size of images.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-13-revisioning.mdx b/src/content/journal/2014/gulp-tutorial-13-revisioning.mdx
index c095b53..9417d65 100644
--- a/src/content/journal/2014/gulp-tutorial-13-revisioning.mdx
+++ b/src/content/journal/2014/gulp-tutorial-13-revisioning.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-13-revisioning
author: Stefan Imhoff
date: 2014-10-30T07:45:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to use revisioning to allow long caching of your assets and replace them with hashed file names, that can be cache-busted."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -39,7 +39,7 @@ var config = require("../../config").copyfonts.production;
* Copy fonts to folder
*/
gulp.task("copy:fonts:production", function () {
- return gulp.src(config.src).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(gulp.dest(config.dest));
});
```
@@ -95,13 +95,13 @@ var config = require("../../config").revision;
* write a manifest file
*/
gulp.task("revision", function () {
- return gulp
- .src(config.src.assets, { base: config.src.base })
- .pipe(gulp.dest(config.dest.assets))
- .pipe(rev())
- .pipe(gulp.dest(config.dest.assets))
- .pipe(rev.manifest({ path: config.dest.manifest.name }))
- .pipe(gulp.dest(config.dest.manifest.path));
+ return gulp
+ .src(config.src.assets, { base: config.src.base })
+ .pipe(gulp.dest(config.dest.assets))
+ .pipe(rev())
+ .pipe(gulp.dest(config.dest.assets))
+ .pipe(rev.manifest({ path: config.dest.manifest.name }))
+ .pipe(gulp.dest(config.dest.manifest.path));
});
```
@@ -142,7 +142,7 @@ var config = require("../../config").collect;
* from a manifest file
*/
gulp.task("rev:collect", function () {
- return gulp.src(config.src).pipe(collect()).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(collect()).pipe(gulp.dest(config.dest));
});
```
@@ -155,5 +155,5 @@ The production build is finished! Only one thing is missing to complete this ser
This concludes the 13th part of my series, _Introduction to Gulp.js_. Today we learned how to revise the asset files and replace links to these files.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-14-deploying-the-website.mdx b/src/content/journal/2014/gulp-tutorial-14-deploying-the-website.mdx
index d7d1cd9..5abce70 100644
--- a/src/content/journal/2014/gulp-tutorial-14-deploying-the-website.mdx
+++ b/src/content/journal/2014/gulp-tutorial-14-deploying-the-website.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-14-deploying-the-website
author: Stefan Imhoff
date: 2014-10-31T08:00:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to deploy your website with rsync to your server."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -70,7 +70,7 @@ var config = require("../../config").rsync;
* via rsync
*/
gulp.task("rsync", function () {
- return gulp.src(config.src).pipe(rsync(config.options));
+ return gulp.src(config.src).pipe(rsync(config.options));
});
```
@@ -81,5 +81,5 @@ This concludes the series _Introduction to Gulp.js_. Developing and deploying wi
I like the UNIX philosophy of Gulp.js: Having small files, which do one task and connect these to larger workflows. And because I kept my Gulp.js tasks small, pluggable, and shareable, I was able to add Gulp.js to my second website in less than five minutes.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-15-performance-improvements-webp-gzip.mdx b/src/content/journal/2014/gulp-tutorial-15-performance-improvements-webp-gzip.mdx
index 1b1d921..a39c122 100644
--- a/src/content/journal/2014/gulp-tutorial-15-performance-improvements-webp-gzip.mdx
+++ b/src/content/journal/2014/gulp-tutorial-15-performance-improvements-webp-gzip.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-15-performance-improvements-webp-gzip
author: Stefan Imhoff
date: 2014-12-21T11:15:00+01:00
description: "The ultimate tutorial and guide for Gulp.js: How to improve the speed and performance of your website with WebP and Gzip."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -50,7 +50,7 @@ var config = require("../../config").webp;
* Convert images to WebP
*/
gulp.task("webp", function () {
- return gulp.src(config.src).pipe(webp(config.options)).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(webp(config.options)).pipe(gulp.dest(config.dest));
});
```
@@ -66,15 +66,15 @@ var runSequence = require("run-sequence");
* Run all tasks needed for a build in the defined order
*/
gulp.task("build:production", function (callback) {
- runSequence(
- "delete",
- "jekyll:production",
- // ...,
- "revision",
- "rev:collect",
- "webp",
- callback
- );
+ runSequence(
+ "delete",
+ "jekyll:production",
+ // ...,
+ "revision",
+ "rev:collect",
+ "webp",
+ callback
+ );
});
```
@@ -149,7 +149,7 @@ var config = require("../../config").gzip;
* Gzip text files
*/
gulp.task("gzip", function () {
- return gulp.src(config.src).pipe(gzip(config.options)).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(gzip(config.options)).pipe(gulp.dest(config.dest));
});
```
@@ -165,15 +165,15 @@ var runSequence = require("run-sequence");
* Run all tasks needed for a build in the defined order
*/
gulp.task("build:production", function (callback) {
- runSequence(
- "delete",
- "jekyll:production",
- // ...,
- "revision",
- "rev:collect",
- ["webp", "gzip"],
- callback
- );
+ runSequence(
+ "delete",
+ "jekyll:production",
+ // ...,
+ "revision",
+ "rev:collect",
+ ["webp", "gzip"],
+ callback
+ );
});
```
@@ -182,5 +182,5 @@ gulp.task("build:production", function (callback) {
This concludes the 15th part of my series _Introduction to Gulp.js_. We learned how to convert images to the WebP format and how to compress text files with Gzip. Every byte we can reduce will increase the speed of the website.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-16-postcss.mdx b/src/content/journal/2014/gulp-tutorial-16-postcss.mdx
index 6301c6a..7687f08 100644
--- a/src/content/journal/2014/gulp-tutorial-16-postcss.mdx
+++ b/src/content/journal/2014/gulp-tutorial-16-postcss.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-16-postcss
author: Stefan Imhoff
date: 2014-12-30T07:50:29+00:00
description: "The ultimate tutorial and guide for Gulp.js: How to use PostCSS with Gulp to process CSS and how to lint your CSS files with Stylelint."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -86,9 +86,9 @@ var mqpacker = require("css-mqpacker");
var config = require("../../config");
function onError(err) {
- gutil.beep();
- console.log(err);
- this.emit("end");
+ gutil.beep();
+ console.log(err);
+ this.emit("end");
}
/**
@@ -96,26 +96,26 @@ function onError(err) {
* Build sourcemaps and minimize
*/
var processors = [
- precss(config.styles.options.precss),
- autoprefixer(config.styles.options.autoprefixer),
- mqpacker(config.styles.options.mqpacker),
+ precss(config.styles.options.precss),
+ autoprefixer(config.styles.options.autoprefixer),
+ mqpacker(config.styles.options.mqpacker),
];
gulp.task("styles", function () {
- browsersync.notify("Transforming CSS with PostCSS");
+ browsersync.notify("Transforming CSS with PostCSS");
- return gulp
- .src(config.styles.src)
- .pipe(
- plumber({
- errorHandler: onError,
- })
- )
- .pipe(sourcemaps.init())
- .pipe(postcss(processors))
- .pipe(nano())
- .pipe(sourcemaps.write("."))
- .pipe(gulp.dest(config.styles.dest));
+ return gulp
+ .src(config.styles.src)
+ .pipe(
+ plumber({
+ errorHandler: onError,
+ })
+ )
+ .pipe(sourcemaps.init())
+ .pipe(postcss(processors))
+ .pipe(nano())
+ .pipe(sourcemaps.write("."))
+ .pipe(gulp.dest(config.styles.dest));
});
```
@@ -275,14 +275,14 @@ var reporter = require("postcss-reporter");
var config = require("../../config");
gulp.task("lint-styles", function () {
- return gulp
- .src(config.lintStyles.src)
- .pipe(
- postcss([
- stylelint(config.lintStyles.options.stylelint),
- reporter(config.lintStyles.options.reporter),
- ])
- );
+ return gulp
+ .src(config.lintStyles.src)
+ .pipe(
+ postcss([
+ stylelint(config.lintStyles.options.stylelint),
+ reporter(config.lintStyles.options.reporter),
+ ])
+ );
});
```
@@ -306,5 +306,5 @@ I’m sure we will see more exciting Plugins in the future.
This concludes the 16th part of my series _Introduction to Gulp.js_. We learned how to use PostCSS to process our CSS files and how to use Stylelint to lint the CSS files for errors.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-2-development-server-browsersync-configuration.mdx b/src/content/journal/2014/gulp-tutorial-2-development-server-browsersync-configuration.mdx
index 52db56c..4873723 100644
--- a/src/content/journal/2014/gulp-tutorial-2-development-server-browsersync-configuration.mdx
+++ b/src/content/journal/2014/gulp-tutorial-2-development-server-browsersync-configuration.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-2-development-server-browsersync-configuration
author: Stefan Imhoff
date: 2014-10-19T10:17:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to set up a development server with BrowserSync."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -29,7 +29,7 @@ I create inside the `gulp/tasks` folder a file `default.js` and write this code:
var gulp = require("gulp");
gulp.task("default", function () {
- console.log("Hello Gulp.js!");
+ console.log("Hello Gulp.js!");
});
```
@@ -93,7 +93,7 @@ var config = require("../../config").browsersync.development;
* Run the build task and start a server with BrowserSync
*/
gulp.task("browsersync", ["build"], function () {
- browsersync(config);
+ browsersync(config);
});
```
@@ -117,20 +117,20 @@ var developmentAssets = "build/assets";
var productionAssets = "build/production/assets";
module.exports = {
- browsersync: {
- development: {
- server: {
- baseDir: [development, build, src],
- },
- port: 9999,
- files: [
- developmentAssets + "/css/*.css",
- developmentAssets + "/js/*.js",
- developmentAssets + "/images/**",
- developmentAssets + "/fonts/*",
- ],
- },
- },
+ browsersync: {
+ development: {
+ server: {
+ baseDir: [development, build, src],
+ },
+ port: 9999,
+ files: [
+ developmentAssets + "/css/*.css",
+ developmentAssets + "/js/*.js",
+ developmentAssets + "/images/**",
+ developmentAssets + "/fonts/*",
+ ],
+ },
+ },
};
```
@@ -145,5 +145,5 @@ BrowserSync watches my asset files, in order that my browser won’t reload like
This concludes the 2nd part of my series _Introduction to Gulp.js_. We learned how to install Gulp.js, write a Gulp.js task, run other tasks, and set up a development server with BrowserSync.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-3-build-clean-jekyll.mdx b/src/content/journal/2014/gulp-tutorial-3-build-clean-jekyll.mdx
index 75a0af3..9f8162f 100644
--- a/src/content/journal/2014/gulp-tutorial-3-build-clean-jekyll.mdx
+++ b/src/content/journal/2014/gulp-tutorial-3-build-clean-jekyll.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-3-build-clean-jekyll
author: Stefan Imhoff
date: 2014-10-20T10:00:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to write tasks for cleaning files and folders, generating the build and the website with Jekyll."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -31,7 +31,7 @@ var runSequence = require("run-sequence");
* Run all tasks needed for a build in a defined order
*/
gulp.task("build", function (callback) {
- runSequence("delete", ["jekyll", "sass", "scripts", "images", "copy:fonts"], "base64", callback);
+ runSequence("delete", ["jekyll", "sass", "scripts", "images", "copy:fonts"], "base64", callback);
});
```
@@ -75,7 +75,7 @@ var config = require("../../config").delete;
* Delete folders and files
*/
gulp.task("delete", function (callback) {
- del(config.src, callback);
+ del(config.src, callback);
});
```
@@ -109,27 +109,27 @@ var config = require("../../config").jekyll.development;
* Build the Jekyll Site
*/
gulp.task("jekyll", function (done) {
- browsersync.notify("Compiling Jekyll");
+ browsersync.notify("Compiling Jekyll");
- return cp
- .spawn(
- "bundle",
- [
- "exec",
- "jekyll",
- "build",
- "-q",
- "--source=" + config.src,
- "--destination=" + config.dest,
- "--config=" + config.config,
- ],
- { stdio: "inherit" }
- )
- .on("close", done);
+ return cp
+ .spawn(
+ "bundle",
+ [
+ "exec",
+ "jekyll",
+ "build",
+ "-q",
+ "--source=" + config.src,
+ "--destination=" + config.dest,
+ "--config=" + config.config,
+ ],
+ { stdio: "inherit" }
+ )
+ .on("close", done);
});
gulp.task("jekyll-rebuild", ["jekyll"], function () {
- browsersync.reload();
+ browsersync.reload();
});
```
@@ -152,5 +152,5 @@ I have a second Jekyll build task `jekyll-rebuild`, which is only a wrapper for
This concludes the 3rd part of my series, _Introduction to Gulp.js_. We learned how to run files in specified order with `run-sequence`, how to delete files and folders, and how to execute a shell task like Jekyll.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-4-css-generation-sass.mdx b/src/content/journal/2014/gulp-tutorial-4-css-generation-sass.mdx
index 92ef6ae..d670631 100644
--- a/src/content/journal/2014/gulp-tutorial-4-css-generation-sass.mdx
+++ b/src/content/journal/2014/gulp-tutorial-4-css-generation-sass.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-4-css-generation-sass
author: Stefan Imhoff
date: 2014-10-21T10:30:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to create CSS and Source Maps with Sass and Compass."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -67,28 +67,28 @@ var config = require("../../config");
* Build sourcemaps
*/
gulp.task("sass", function () {
- var sassConfig = config.sass.options;
+ var sassConfig = config.sass.options;
- sassConfig.onError = browsersync.notify;
+ sassConfig.onError = browsersync.notify;
- // Don’t write sourcemaps of sourcemaps
- var filter = gulpFilter(["*.css", "!*.map"], { restore: true });
+ // Don’t write sourcemaps of sourcemaps
+ var filter = gulpFilter(["*.css", "!*.map"], { restore: true });
- browsersync.notify("Compiling Sass");
+ browsersync.notify("Compiling Sass");
- return sass(config.sass.src, sassConfig)
- .pipe(plumber())
- .pipe(sourcemaps.init())
- .pipe(autoprefixer(config.autoprefixer))
- .pipe(filter) // Don’t write sourcemaps of sourcemaps
- .pipe(
- sourcemaps.write(".", {
- includeContent: false,
- sourceRoot: "app/_assets/scss",
- })
- )
- .pipe(filter.restore) // Restore original files
- .pipe(gulp.dest(config.sass.dest));
+ return sass(config.sass.src, sassConfig)
+ .pipe(plumber())
+ .pipe(sourcemaps.init())
+ .pipe(autoprefixer(config.autoprefixer))
+ .pipe(filter) // Don’t write sourcemaps of sourcemaps
+ .pipe(
+ sourcemaps.write(".", {
+ includeContent: false,
+ sourceRoot: "app/_assets/scss",
+ })
+ )
+ .pipe(filter.restore) // Restore original files
+ .pipe(gulp.dest(config.sass.dest));
});
```
@@ -103,5 +103,5 @@ You might have guessed: If you wish to use Compass, set the option `compass` to
This concludes the 4th part of my series, _Introduction to Gulp.js_. We learned how to keep Gulp.js running, even when we produce errors, how to preprocess SCSS files with Sass, create Source Maps, and add vendor prefixes to the CSS files.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-5-javascripts-browserify.mdx b/src/content/journal/2014/gulp-tutorial-5-javascripts-browserify.mdx
index b66edc7..c2a9493 100644
--- a/src/content/journal/2014/gulp-tutorial-5-javascripts-browserify.mdx
+++ b/src/content/journal/2014/gulp-tutorial-5-javascripts-browserify.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-5-javascripts-browserify
author: Stefan Imhoff
date: 2014-10-22T08:00:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to bundle JavaScript files with Browserify and use CommonJS modules to structure and organize your code."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -67,69 +67,69 @@ var config = require("../../config").browserify;
* Run JavaScript through Browserify
*/
gulp.task("scripts", function (callback) {
- browsersync.notify("Compiling JavaScript");
+ browsersync.notify("Compiling JavaScript");
- var bundleQueue = config.bundleConfigs.length;
+ var bundleQueue = config.bundleConfigs.length;
- var browserifyThis = function (bundleConfig) {
- var bundler = browserify({
- // Required watchify args
- cache: {},
- packageCache: {},
- fullPaths: false,
- // Specify the entry point of your app
- entries: bundleConfig.entries,
- // Add file extensions to make optional in your requires
- extensions: config.extensions,
- // Enable source maps!
- debug: config.debug,
- });
+ var browserifyThis = function (bundleConfig) {
+ var bundler = browserify({
+ // Required watchify args
+ cache: {},
+ packageCache: {},
+ fullPaths: false,
+ // Specify the entry point of your app
+ entries: bundleConfig.entries,
+ // Add file extensions to make optional in your requires
+ extensions: config.extensions,
+ // Enable source maps!
+ debug: config.debug,
+ });
- var bundle = function () {
- // Log when bundling starts
- bundleLogger.start(bundleConfig.outputName);
+ var bundle = function () {
+ // Log when bundling starts
+ bundleLogger.start(bundleConfig.outputName);
- return (
- bundler
- .bundle()
- // Report compile errors
- .on("error", handleErrors)
- // Use vinyl-source-stream to make the
- // stream gulp compatible. Specify the
- // desired output filename here.
- .pipe(source(bundleConfig.outputName))
- // Specify the output destination
- .pipe(gulp.dest(bundleConfig.dest))
- .on("end", reportFinished)
- );
- };
+ return (
+ bundler
+ .bundle()
+ // Report compile errors
+ .on("error", handleErrors)
+ // Use vinyl-source-stream to make the
+ // stream gulp compatible. Specify the
+ // desired output filename here.
+ .pipe(source(bundleConfig.outputName))
+ // Specify the output destination
+ .pipe(gulp.dest(bundleConfig.dest))
+ .on("end", reportFinished)
+ );
+ };
- if (global.isWatching) {
- // Wrap with watchify and rebundle on changes
- bundler = watchify(bundler);
- // Rebundle on update
- bundler.on("update", bundle);
- }
+ if (global.isWatching) {
+ // Wrap with watchify and rebundle on changes
+ bundler = watchify(bundler);
+ // Rebundle on update
+ bundler.on("update", bundle);
+ }
- var reportFinished = function () {
- // Log when bundling completes
- bundleLogger.end(bundleConfig.outputName);
+ var reportFinished = function () {
+ // Log when bundling completes
+ bundleLogger.end(bundleConfig.outputName);
- if (bundleQueue) {
- bundleQueue--;
- if (bundleQueue === 0) {
- // If queue is empty, tell gulp the task is complete.
- // https://github.com/gulpjs/gulp/blob/master/docs/API.md#accept-a-callback
- callback();
- }
- }
- };
+ if (bundleQueue) {
+ bundleQueue--;
+ if (bundleQueue === 0) {
+ // If queue is empty, tell gulp the task is complete.
+ // https://github.com/gulpjs/gulp/blob/master/docs/API.md#accept-a-callback
+ callback();
+ }
+ }
+ };
- return bundle();
- };
+ return bundle();
+ };
- // Start bundling with Browserify for each bundleConfig specified
- config.bundleConfigs.forEach(browserifyThis);
+ // Start bundling with Browserify for each bundleConfig specified
+ config.bundleConfigs.forEach(browserifyThis);
});
```
@@ -148,16 +148,16 @@ var prettyHrtime = require("pretty-hrtime");
var startTime;
module.exports = {
- start: function (filepath) {
- startTime = process.hrtime();
- gutil.log("Bundling", gutil.colors.green(filepath));
- },
+ start: function (filepath) {
+ startTime = process.hrtime();
+ gutil.log("Bundling", gutil.colors.green(filepath));
+ },
- end: function (filepath) {
- var taskTime = process.hrtime(startTime);
- var prettyTime = prettyHrtime(taskTime);
- gutil.log("Bundled", gutil.colors.green(filepath), "in", gutil.colors.magenta(prettyTime));
- },
+ end: function (filepath) {
+ var taskTime = process.hrtime(startTime);
+ var prettyTime = prettyHrtime(taskTime);
+ gutil.log("Bundled", gutil.colors.green(filepath), "in", gutil.colors.magenta(prettyTime));
+ },
};
```
@@ -167,18 +167,18 @@ module.exports = {
var notify = require("gulp-notify");
module.exports = function () {
- var args = Array.prototype.slice.call(arguments);
+ var args = Array.prototype.slice.call(arguments);
- // Send error to notification center with gulp-notify
- notify
- .onError({
- title: "Compile Error",
- message: "<%= error.message %>",
- })
- .apply(this, args);
+ // Send error to notification center with gulp-notify
+ notify
+ .onError({
+ title: "Compile Error",
+ message: "<%= error.message %>",
+ })
+ .apply(this, args);
- // Keep gulp from hanging on to this task
- this.emit("end");
+ // Keep gulp from hanging on to this task
+ this.emit("end");
};
```
@@ -216,7 +216,7 @@ Later, you import your modules and use them:
var add = require("./math").add;
exports.increment = function (val) {
- return add(val, 1);
+ return add(val, 1);
};
```
@@ -227,7 +227,7 @@ var navigation = require("./navigation");
var triggerNavigation = document.querySelector(".toggle-navigation");
document.addEventListener("DOMContentLoaded", function () {
- triggerNavigation.addEventListener("click", navigation.toggleNavigation);
+ triggerNavigation.addEventListener("click", navigation.toggleNavigation);
});
```
@@ -247,21 +247,21 @@ I open my `package.json` file and need to add a few lines:
```json
{
- "...": "...",
- "browser": {
- "modernizr": "./app/_bower_components/modernizr/modernizr.js",
- "jquery": "./app/_bower_components/jquery/dist/jquery.js"
- },
- "browserify-shim": {
- "modernizr": "Modernizr",
- "jquery": "$"
- },
- "browserify": {
- "transform": ["browserify-shim"]
- },
- "devDependencies": {
- "...": "..."
- }
+ "...": "...",
+ "browser": {
+ "modernizr": "./app/_bower_components/modernizr/modernizr.js",
+ "jquery": "./app/_bower_components/jquery/dist/jquery.js"
+ },
+ "browserify-shim": {
+ "modernizr": "Modernizr",
+ "jquery": "$"
+ },
+ "browserify": {
+ "transform": ["browserify-shim"]
+ },
+ "devDependencies": {
+ "...": "..."
+ }
}
```
@@ -281,7 +281,7 @@ require("modernizr");
require("jquery");
$(function () {
- console.log("jQuery and Modernizr loaded");
+ console.log("jQuery and Modernizr loaded");
});
```
@@ -292,5 +292,5 @@ You have to run `npm install` once you added a new entry to your `package.json`
This concludes the 5th part of my series, _Introduction to Gulp.js_. We learned how to use Browserify to bundle JavaScript files, how to use CommonJS modules to run Node in your Browser, and how to use non-CommonJS JavaScript files.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-6-images-vector-fonts.mdx b/src/content/journal/2014/gulp-tutorial-6-images-vector-fonts.mdx
index a37fbc7..ad47ca3 100644
--- a/src/content/journal/2014/gulp-tutorial-6-images-vector-fonts.mdx
+++ b/src/content/journal/2014/gulp-tutorial-6-images-vector-fonts.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-6-images-vector-fonts
author: Stefan Imhoff
date: 2014-10-23T08:00:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to move images and generate vector fonts from SVG."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -36,10 +36,10 @@ var config = require("../../config").images;
* if not changed
*/
gulp.task("images", function () {
- return gulp
- .src(config.src)
- .pipe(changed(config.dest)) // Ignore unchanged files
- .pipe(gulp.dest(config.dest));
+ return gulp
+ .src(config.src)
+ .pipe(changed(config.dest)) // Ignore unchanged files
+ .pipe(gulp.dest(config.dest));
});
```
@@ -132,7 +132,7 @@ var config = require("../../config").copyfonts.development;
* Copy fonts to folder
*/
gulp.task("copy:fonts", ["fontcustom"], function () {
- return gulp.src(config.src).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(gulp.dest(config.dest));
});
```
@@ -179,5 +179,5 @@ After you add the line for `fontcustom` you will have to run `bundle install` ag
This concludes the 6th part of my series, _Introduction to Gulp.js_. We learned how to move files with Gulp.js (and don’t even need a plugin for that), and how I create my vector fonts. Nothing special, but the next part will be more interesting again.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-7-base64.mdx b/src/content/journal/2014/gulp-tutorial-7-base64.mdx
index 68c48bb..2e24470 100644
--- a/src/content/journal/2014/gulp-tutorial-7-base64.mdx
+++ b/src/content/journal/2014/gulp-tutorial-7-base64.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-7-base64
author: Stefan Imhoff
date: 2014-10-24T07:30:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to replace small images with base64 encoded images."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -19,13 +19,13 @@ To load the background pattern, I use SCSS like this:
```scss
%pattern-light-grey {
- background-color: $background-color;
- background-image: url(/assets/images/patterns/light_grey.png);
- background-size: 301px 621px;
+ background-color: $background-color;
+ background-image: url(/assets/images/patterns/light_grey.png);
+ background-size: 301px 621px;
}
body {
- @extend %pattern-light-grey;
+ @extend %pattern-light-grey;
}
```
@@ -33,9 +33,9 @@ The generated CSS looks like this:
```css
body {
- background-color: #fdfdfd;
- background-image: url(/assets/images/patterns/light_grey.png);
- background-size: 301px 621px;
+ background-color: #fdfdfd;
+ background-image: url(/assets/images/patterns/light_grey.png);
+ background-size: 301px 621px;
}
```
@@ -43,9 +43,9 @@ After the task ran, the CSS will look like this:
```css
body {
- background-color: #fdfdfd;
- background-image: url(…);
- background-size: 301px 621px;
+ background-color: #fdfdfd;
+ background-image: url(…);
+ background-size: 301px 621px;
}
```
@@ -85,7 +85,7 @@ var config = require("../../config").base64;
* Replace urls in CSS files with base64 encoded data
*/
gulp.task("base64", ["sass"], function () {
- return gulp.src(config.src).pipe(base64(config.options)).pipe(gulp.dest(config.dest));
+ return gulp.src(config.src).pipe(base64(config.options)).pipe(gulp.dest(config.dest));
});
```
@@ -96,5 +96,5 @@ We are now finished with the development `build` task.
This concludes the 7th part of my series, _Introduction to Gulp.js_. We learned how to replace URLs to PNGs with Base64 encoded images. And we are now finished with our `build` task.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-8-watch.mdx b/src/content/journal/2014/gulp-tutorial-8-watch.mdx
index 40e5bb0..e014f7a 100644
--- a/src/content/journal/2014/gulp-tutorial-8-watch.mdx
+++ b/src/content/journal/2014/gulp-tutorial-8-watch.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-8-watch
author: Stefan Imhoff
date: 2014-10-25T10:00:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to set up a watch task, which triggers other tasks on file changes."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -52,12 +52,12 @@ var config = require("../../config").watch;
* Start browsersync task and then watch files for changes
*/
gulp.task("watch", ["browsersync"], function () {
- gulp.watch(config.jekyll, ["jekyll-rebuild"]);
- gulp.watch(config.sass, ["sass", "scsslint"]);
- gulp.watch(config.scripts, ["scripts", "jshint"]);
- gulp.watch(config.images, ["images"]);
- gulp.watch(config.svg, ["copy:fonts"]);
- gulp.watch(config.sprites, ["sprites"]);
+ gulp.watch(config.jekyll, ["jekyll-rebuild"]);
+ gulp.watch(config.sass, ["sass", "scsslint"]);
+ gulp.watch(config.scripts, ["scripts", "jshint"]);
+ gulp.watch(config.images, ["images"]);
+ gulp.watch(config.svg, ["copy:fonts"]);
+ gulp.watch(config.sprites, ["sprites"]);
});
```
@@ -76,5 +76,5 @@ I miss now three tasks: `scsslint`, `jshint`, and `sprites`.
This concludes the 8th part of my series, _Introduction to Gulp.js_. We learned how to use Gulp.js to watch for changes, deletion, or creation of files and how to trigger tasks. And the best part is: This is part of the Gulp.js API. We don’t need any plugins.
-
+
diff --git a/src/content/journal/2014/gulp-tutorial-9-linting-scss-and-javascript.mdx b/src/content/journal/2014/gulp-tutorial-9-linting-scss-and-javascript.mdx
index ff6ff64..39eddc5 100644
--- a/src/content/journal/2014/gulp-tutorial-9-linting-scss-and-javascript.mdx
+++ b/src/content/journal/2014/gulp-tutorial-9-linting-scss-and-javascript.mdx
@@ -4,7 +4,7 @@ slug: gulp-tutorial-9-linting-scss-and-javascript
author: Stefan Imhoff
date: 2014-10-26T08:10:00+02:00
description: "The ultimate tutorial and guide for Gulp.js: How to check the syntax of SCSS and JavaScript files."
-cover: /assets/images/cover/gulp.svg
+cover: /assets/images/cover/gulp.jpg
tags: ["code"]
series: gulp
---
@@ -64,7 +64,7 @@ var config = require("../../config").scsslint;
* `gem install scss-lint` needed
*/
gulp.task("scsslint", function () {
- return gulp.src(config.src).pipe(scsslint(config.options));
+ return gulp.src(config.src).pipe(scsslint(config.options));
});
```
@@ -80,7 +80,7 @@ var config = require("../../config").jshint;
* Check JavaScript syntax with JSHint
*/
gulp.task("jshint", function () {
- return gulp.src(config.src).pipe(jshint()).pipe(jshint.reporter(stylish));
+ return gulp.src(config.src).pipe(jshint()).pipe(jshint.reporter(stylish));
});
```
@@ -97,5 +97,5 @@ To find out which options are available, look into the documentation of [SCSS-Li
This concludes the 9th part of my series, _Introduction to Gulp.js_. Today, we learned how to use Gulp.js to check the syntax of SCSS and JavaScript files. This task will run continuously while I write my files and print out errors to my console the moment I created them.
-
+