DWB
DWB copied to clipboard
:high_brightness: A flexible two-column Jekyll Liquid theme. ALL UI with React, - "Apollo and GraphQL - on workers", - Netlify for Functions. Netlify Identity for oAuth, with Netlify Cms with a Apoll...
Don Boulton version Of: MMistakes with React Webpack & Netlify Identity Widget with a Netlify CMS - GraphQL Backend
Jekyll based Minimal Mistakes Jekyll Theme
Authentication
Netlify Identity Widget
A component used to authenticate with Netlify's Identity service. Live demo
For a lower level library to the underlying GoTrue API, see gotrue-js.
What is Netlify Identity
Netlifyβs Identity service is a plug-and-play microservice for handling site functionalities like signups, logins, password recovery, user metadata, and roles. You can use it from single page apps instead of rolling your own, and integrate with any service that understands JSON Web Tokens (JWTs).
Learn more about this service from this blog post.
donboulton.com uses a custom Webpack Preact build of the Netlify Identity Widget found in this repo.
GraphQL Backend
[](href="https://raw.githubusercontent.com/donaldboulton/DWB/gh-pages/types.graphql" rel="nofollow"><img src="https://camo.githubusercontent.com/f340241ecd8a23f3583494d0b883ad0ea488ea3f/687474703a2f2f7374617469632e67726170682e636f6f6c2f696d616765732f6772617068716c2d75702e737667" alt="graphql-up" data-canonical-src="http://static.graph.cool/images/graphql-up.svg")
Setup your GraphQL backend using the graphql-up button at the top of this section. Once your backend is created in Graphcool, copy your GraphQL enpoint using the enpoints link.
2. Retrieve GitHub Access Token
!Important: π To get access to the GitHub early access GraphQL API, fill out the prerelease agreement
You will need a GitHub access token to access the repository data fetching portion of this app. You can find instructions on how to retrieve one on GitHub.
Be sure to allow access to your user information when creating your token.
Netlify CMS Backend
This donboulton.com website is a static website but has a administration backend through Netlify CMS. Adding custom notifications, events, contacts and updates to Netlify CMS _config.yml
Users that register on this site will be added to My Netlify Contacts, Using Zapper to zap users data to Google Contacts, and to my event calendars and zapped to back my repo for a saved locally contacts.json data file which hashes email addresses and other personal data for site and Users security.
Events will be displayed on my events calendar calendar.
Adding React Components
All react additions were hand build adding components individually in the DOM for now, soon at root levels. The following node react modules added.
Menu built with React A11yDialog
react-a11y-dialog is a React component for a11y-dialog relying on React portals to ease the use of accessible dialog windows in React applications.
Based on A11y Dialog
a11y-dialog is a lightweight (1.3Kb) yet flexible script to create accessible dialog windows.log.
React Notifications
React-web-notification
data:image/s3,"s3://crabby-images/f3cf2/f3cf207b9c79b5ffa395d8b87441908f1bf23817" alt="npm version"
React component with HTML5 Web Notification API.
This component show nothing in dom element, but trigger HTML5 Web Notification API with render
method in the life cycle of React.js.
Demo
Incorporating Jekyll Webpack boilerplate
Adding a Jekyll boilerplate supercharged with React & Webpack to build modern performant websites (including Progressive Web Apps). Read more about how this boilerplate has been built: https://medium.com/learning-lab/5-how-i-learnt-webpack-3-and-created-a-jekyll-and-webpack-boilerplate-edd86645fd5e
Features
Improved workflow
- Webpack working along with Jekyll
- BrowserSync live reload
Optimized Style and SASS
- SASS Style
- PostCSS Auto Preffixer
- CSS minified
- Critical CSS Path added to the main template (using the command with optim)
ES6 & Optimization
- ENV Babel
- JS Webpack minified and Uglified
- ES Lint
Images optimized
- Webpack Imagemin, images optimizations
Write less code
- Theme color in config
- Favicon generated automatically
- Google Analytics setup in config file (optional)
- Doorbell setup in config file (optional)
- Cookie consent setup in config file (optional)
SEO Ready
- SEO Plugin Jekyll
- Sitemap generated
Write better code
- Internationalization plugin
Progressive Web Apps (optional)
- Generation of the Manifest
- Generation of Service worker
Easy to deploy
- Easy deployment with Netlify
Prerequisites
The following tools should be installed before starting:
- NodeJS, npm
- Ruby, Gem, Bundler
- Jekyll
- React
- Webpack
- Sass
Webpack Jekyll Example
This repo Webpack build was originally taken from
Jekyll-webpack-boilerplate Quick start
- Make sure you have all the prerequisites above installed.
- Clone this repo using
git clone https://github.com/sandoche/Jekyll-webpack-boilerplate.git
- Move to the appropriate directory:
cd Jekyll-webpack-boilerplate
. - Run
npm install
andbundler install
in order to install dependencies and clean the git repo. - Run
npm start
to start the development server (or usenpm start
).
Quick deployment
Here is a demo of the Webpack boilerplate Netlify build: https://dazzling-swartz-9738b5.netlify.com
Development
To start the development server just run npm start
Folder structure
.
βββ pages
| |ββ404.html
| |ββabout.md
βββ config <--- This folder contains the different Webpack config files
β βββ optimization-fix <--- A fix for optimization, do not delete this folder
β βββ postcss.config.js <--- Post css config
β βββ sw.config.js <--- The service worker config file
β βββ webpack.common.js <--- The common Webpack config file for all the environment
β βββ webpack.dev.js <--- Dev Webpack environment config file
β βββ webpack.optim.js <--- This is used to add the css critical path in the default template
β βββ webpack.prod.js <--- Prod Webpack environment config file
β βββ webpack.pwa.js <--- Please edit this file if you want a PWA
βββ _config.yml <--- The Jekyll config file that you need to set up
βββ Gemfile
βββ Gemfile.lock
βββ _i18n <--- Contains your posts and data in the language you need (check below how to remove it)
βββ _images <--- Put all your images here, you will access them with this path /assets/images/
β βββ icon.png <--- Replace this with your icon
β βββ large-icon.png <--- Replace this with your Facebook Open Graph picture
βββ icon.png <--- Same with this one
βββ _includes
βββ index.html
βββ _layouts
β βββ amp.html <--- The layout for Accelerated mobile page
β βββ blog.html
β βββ home.html
β βββ page.html
β βββ post.html
βββ LICENSE
βββ package.json <--- Update this file with your information especially the name which is used for the meta tags
βββ README.md
βββ _scss <--- Put your partials here
β βββ _default.scss
βββ _src <--- This folder contains your JS and SASS entry points
β βββ index.js
β βββ index.scss
β βββ template
β βββ default.html <--- Here is the main default template, feel free to edit it but do not delete it
βββ webpack.config.js
βββ package-lock.json
You can see above the basic structure of the boilerplate and the main differences with the official Jekyll folder structure
Configurations
- The required configurations are all in
_config.yml
- Also edit
package.json
the name is used in the meta tags - If you want a
manifest.json
file please editconfig/webpack.pwa.js
- Replace the different icon by yours in
_images
and in the root folder
Assets
- SCSS partials should be located in
_scss
for better reading - Put all your images in
_images
the content of this folder will be moved to the_site/assets/images
so you can access them with this path/assets/images/**
in your templates, check the examples - Put all your JavaScript files inside
_src
and import them fromindex.js
or you can also add them as a new entry point in your Webpack configuration file
Internationalization
- All the posts should be there in inside
_i18n
folder inside its language, check the boilerplate examples - You can put your variables inside
_i18n/en.yml
(replace en with your language) and call them in your template with{% t variable_name.sub_variable %}
- You can remove the plugin by removing
gem 'jekyll-multiple-languages-plugin'
fromgemfile
andjekyll-multiple-languages-plugin
fromplugins
in_config.yml
- We invite you to read the very good official documentation of the plugin Jekyll multiple language plugin
Build
Optimized website
To build the website run the following line
npm run build
Or if you want the critical css
npm run build:optim
The built website will be in _site
folder.
You can also run a local server to test it with this command
npm run serve:dist
PWA
If you want to build a PWA (including the manifest.json and the service worker) run the following. Please ensure to have configured this file config/webpack.pwa.js
The built website will be in _site
folder.
npm run build:pwa
Or if you want the critical css with pwa
npm run build:pwa:optim
Clean assets & _site folders
This will remove the generated folders
npm run clean:project
Known issues
- Jekyll watch doesn't reload / rebuild when a translation file is updated inside
_i18n
folder, I recommend to removejekyll-multiple-languages-plugin
if you don't want a multi language website and if you want to watch / rebuild faster. Otherwise close and startnpm run start
to rebuild and see your changes from_i18n
- The critical CSS Path may show some weird behavior when the page is loading that is why there are separated npm scripts
Websites using Jekyll Webpack Boilerplate
- Donald Boulton - https://donboulton.com
- Typster - https://typster.xyz
- TEDxMarseille - https://tedxmarseille.com
- Motive network - https://motive.network
- CoinGenerator - https://coingenerator.sh
Other documentations
- Jekyll
- Webpack
- React *
- Jekyll multiple languages plugin
- Jekyll SEO tag
- BrowserSync Webpack plugin
- PostCSS
Credits
Creator of Jekyll Framework
Michael Rose
Other
License
The MIT License (MIT)
Copyright (c) 2013-2018 Donald Boulton and contributors
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Minimal Mistakes incorporates icons from The Noun Project creators Garrett Knoll, Arthur Shlain, and tracy tam. Icons are distributed under Creative Commons Attribution 3.0 United States (CC BY 3.0 US).
Minimal Mistakes incorporates Font Awesome, Copyright (c) 2017 Dave Gandy. Font Awesome is distributed under the terms of the SIL OFL 1.1 and MIT License.
Minimal Mistakes incorporates photographs from Unsplash.
Minimal Mistakes incorporates Susy, Copyright (c) 2017, Miriam Eric Suzanne. Susy is distributed under the terms of the BSD 3-clause "New" or "Revised" License.
Minimal Mistakes incorporates Breakpoint. Breakpoint is distributed under the terms of the MIT/GPL Licenses.
Minimal Mistakes incorporates FitVids.js, Copyright (c) 2013 Dave Rubert and Chris Coyier. FitVids is distributed under the terms of the WTFPL License.
Minimal Mistakes incorporates Magnific Popup, Copyright (c) 2014-2016 Dmitry Semenov, https://dimsemenov.com. Magnific Popup is distributed under the terms of the MIT License.
Minimal Mistakes incorporates jQuery Smooth Scroll, Copyright (c) 2017 Karl Swedberg. jQuery Smooth Scroll is distributed under the terms of the MIT License.
Minimal Mistakes incorporates GreedyNav.js, Copyright (c) 2015 Luke Jackson. GreedyNav.js is distributed under the terms of the MIT License.
Minimal Mistakes incorporates Jekyll Group-By-Array, Copyright (c) 2015 Max White [email protected]. Jekyll Group-By-Array is distributed under the terms of the MIT License.
Minimal Mistakes incorporates @allejo's Pure Liquid Jekyll Table of Contents, Copyright (c) 2017 Vladimir Jimenez. Pure Liquid Jekyll Table of Contents is distributed under the terms of the MIT License.
Minimal Mistakes incorporates Lunr, Copyright (c) 2017 Oliver Nightingale. Lunr is distributed under the terms of the MIT License. Everthing else