Drop laravel elixir, we’ll use nginx’s etag feature for cache-ing
This commit is contained in:
parent
779009be3c
commit
13fd7ae736
65 changed files with 585 additions and 2063 deletions
|
@ -16,11 +16,11 @@
|
||||||
"tests"
|
"tests"
|
||||||
],
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"fetch": "~0.11.0",
|
"fetch": "~1.0",
|
||||||
"alertify.js": "alertifyjs#~1.0.5",
|
"alertify.js": "alertifyjs#~1.0.5",
|
||||||
"store2": "~2.3.2",
|
"store2": "~2.3.2",
|
||||||
"Autolinker.js": "~0.24.0",
|
"Autolinker.js": "^0.27.0",
|
||||||
"marked": "~0.3.5",
|
"marked": "~0.3.5",
|
||||||
"sanitize-css": "^3.2.0"
|
"sanitize-css": "^4.1.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
99
gulpfile.js
99
gulpfile.js
|
@ -1,47 +1,22 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
var gulp = require('gulp');
|
var gulp = require('gulp');
|
||||||
|
var sass = require('gulp-sass');
|
||||||
var zopfli = require('gulp-zopfli');
|
var zopfli = require('gulp-zopfli');
|
||||||
var brotli = require('gulp-brotli');
|
var brotli = require('gulp-brotli');
|
||||||
var elixir = require('laravel-elixir');
|
|
||||||
|
|
||||||
/*
|
gulp.task('sass', function () {
|
||||||
|--------------------------------------------------------------------------
|
return gulp.src('./resources/assets/sass/global.scss')
|
||||||
| Elixir Asset Management
|
.pipe(sass().on('error', sass.logError))
|
||||||
|--------------------------------------------------------------------------
|
.pipe(gulp.dest('./public/assets/css'));
|
||||||
|
|
|
||||||
| Elixir provides a clean, fluent API for defining some basic Gulp tasks
|
|
||||||
| for your Laravel application. By default, we are compiling the Sass
|
|
||||||
| file for our application, as well as publishing vendor resources.
|
|
||||||
|
|
|
||||||
*/
|
|
||||||
|
|
||||||
elixir(function(mix) {
|
|
||||||
mix.sass('global.scss', 'public/assets/css');
|
|
||||||
mix.copy('resources/assets/js', 'public/assets/js');
|
|
||||||
mix.version([
|
|
||||||
//hand-made css
|
|
||||||
'assets/css/global.css',
|
|
||||||
'assets/css/projects.css',
|
|
||||||
//hand-made js
|
|
||||||
'assets/js/form-save.js',
|
|
||||||
'assets/js/links.js',
|
|
||||||
'assets/js/maps.js',
|
|
||||||
'assets/js/newplace.js',
|
|
||||||
'assets/js/newnote.js',
|
|
||||||
//bower components
|
|
||||||
'assets/bower/alertify.css',
|
|
||||||
'assets/bower/sanitize.css',
|
|
||||||
'assets/bower/fetch.js',
|
|
||||||
'assets/bower/alertify.js',
|
|
||||||
'assets/bower/store2.min.js',
|
|
||||||
'assets/bower/Autolinker.min.js',
|
|
||||||
'assets/bower/marked.min.js',
|
|
||||||
//prism
|
|
||||||
'assets/prism/prism.js',
|
|
||||||
'assets/prism/prism.css',
|
|
||||||
]);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('bower', function() {
|
gulp.task('js-assets', function () {
|
||||||
|
return gulp.src(['resources/assets/js/**/*'])
|
||||||
|
.pipe(gulp.dest('./public/assets/js'));
|
||||||
|
});
|
||||||
|
|
||||||
|
gulp.task('bower', function () {
|
||||||
//copy JS files
|
//copy JS files
|
||||||
gulp.src([
|
gulp.src([
|
||||||
'bower_components/fetch/fetch.js',
|
'bower_components/fetch/fetch.js',
|
||||||
|
@ -61,43 +36,43 @@ gulp.task('bower', function() {
|
||||||
|
|
||||||
gulp.task('compress', function () {
|
gulp.task('compress', function () {
|
||||||
//hand-made css
|
//hand-made css
|
||||||
gulp.src('public/build/assets/css/*.css')
|
gulp.src('public/assets/css/*.css')
|
||||||
.pipe(zopfli({ format: 'gzip', append: true }))
|
.pipe(zopfli({ format: 'gzip', append: true }))
|
||||||
.pipe(gulp.dest('public/build/assets/css/'));
|
.pipe(gulp.dest('public/assets/css/'));
|
||||||
gulp.src('public/build/assets/css/*.css')
|
gulp.src('public/assets/css/*.css')
|
||||||
.pipe(brotli.compress({mode: 1, quality: 11}))
|
.pipe(brotli.compress({mode: 1, quality: 11}))
|
||||||
.pipe(gulp.dest('public/build/assets/css/'));
|
.pipe(gulp.dest('public/assets/css/'));
|
||||||
//hand-made js
|
//hand-made js
|
||||||
gulp.src('public/build/assets/js/*.js')
|
gulp.src('public/assets/js/*.js')
|
||||||
.pipe(zopfli({ format: 'gzip', append: true }))
|
.pipe(zopfli({ format: 'gzip', append: true }))
|
||||||
.pipe(gulp.dest('public/build/assets/js/'));
|
.pipe(gulp.dest('public/assets/js/'));
|
||||||
gulp.src('public/build/assets/js/*.js')
|
gulp.src('public/assets/js/*.js')
|
||||||
.pipe(brotli.compress({mode: 1, quality: 11}))
|
.pipe(brotli.compress({mode: 1, quality: 11}))
|
||||||
.pipe(gulp.dest('public/build/assets/js/'));
|
.pipe(gulp.dest('public/assets/js/'));
|
||||||
//bower components
|
//bower components
|
||||||
gulp.src('public/build/assets/bower/*.css')
|
gulp.src('public/assets/bower/*.css')
|
||||||
.pipe(zopfli({ format: 'gzip', append: true }))
|
.pipe(zopfli({ format: 'gzip', append: true }))
|
||||||
.pipe(gulp.dest('public/build/assets/bower/'));
|
.pipe(gulp.dest('public/assets/bower/'));
|
||||||
gulp.src('public/build/assets/bower/*.js')
|
gulp.src('public/assets/bower/*.js')
|
||||||
.pipe(zopfli({ format: 'gzip', append: true }))
|
.pipe(zopfli({ format: 'gzip', append: true }))
|
||||||
.pipe(gulp.dest('public/build/assets/bower/'));
|
.pipe(gulp.dest('public/assets/bower/'));
|
||||||
gulp.src('public/build/assets/bower/*.css')
|
gulp.src('public/assets/bower/*.css')
|
||||||
.pipe(brotli.compress({mode: 1, quality: 11}))
|
.pipe(brotli.compress({mode: 1, quality: 11}))
|
||||||
.pipe(gulp.dest('public/build/assets/bower/'));
|
.pipe(gulp.dest('public/assets/bower/'));
|
||||||
gulp.src('public/build/assets/bower/*.js')
|
gulp.src('public/assets/bower/*.js')
|
||||||
.pipe(brotli.compress({mode: 1, quality: 11}))
|
.pipe(brotli.compress({mode: 1, quality: 11}))
|
||||||
.pipe(gulp.dest('public/build/assets/bower/'));
|
.pipe(gulp.dest('public/assets/bower/'));
|
||||||
//prism
|
//prism
|
||||||
gulp.src('public/build/assets/prism/*.css')
|
gulp.src('public/assets/prism/*.css')
|
||||||
.pipe(zopfli({ format: 'gzip', append: true }))
|
.pipe(zopfli({ format: 'gzip', append: true }))
|
||||||
.pipe(gulp.dest('public/build/assets/prism/'));
|
.pipe(gulp.dest('public/assets/prism/'));
|
||||||
gulp.src('public/build/assets/prism/*.js')
|
gulp.src('public/assets/prism/*.js')
|
||||||
.pipe(zopfli({ format: 'gzip', append: true }))
|
.pipe(zopfli({ format: 'gzip', append: true }))
|
||||||
.pipe(gulp.dest('public/build/assets/prism/'));
|
.pipe(gulp.dest('public/assets/prism/'));
|
||||||
gulp.src('public/build/assets/prism/*.css')
|
gulp.src('public/assets/prism/*.css')
|
||||||
.pipe(brotli.compress({mode: 1, quality: 11}))
|
.pipe(brotli.compress({mode: 1, quality: 11}))
|
||||||
.pipe(gulp.dest('public/build/assets/prism/'));
|
.pipe(gulp.dest('public/assets/prism/'));
|
||||||
gulp.src('public/build/assets/prism/*.js')
|
gulp.src('public/assets/prism/*.js')
|
||||||
.pipe(brotli.compress({mode: 1, quality: 11}))
|
.pipe(brotli.compress({mode: 1, quality: 11}))
|
||||||
.pipe(gulp.dest('public/build/assets/prism/'));
|
.pipe(gulp.dest('public/assets/prism/'));
|
||||||
});
|
});
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"gulp": "~3.9",
|
"gulp": "~3.9",
|
||||||
"gulp-brotli": "^1.0.1",
|
"gulp-brotli": "^1.0.1",
|
||||||
|
"gulp-sass": "^2.3.2",
|
||||||
"gulp-zopfli": "^1.0.0",
|
"gulp-zopfli": "^1.0.0",
|
||||||
"laravel-elixir": "^6.0.0-2",
|
|
||||||
"lint-staged": "^1.0.1",
|
"lint-staged": "^1.0.1",
|
||||||
"pre-commit": "^1.1.3",
|
"pre-commit": "^1.1.3",
|
||||||
"stylelint": "^6.6.0",
|
"stylelint": "^6.6.0",
|
||||||
|
@ -15,8 +15,6 @@
|
||||||
},
|
},
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"prod": "gulp --production",
|
|
||||||
"dev": "gulp watch",
|
|
||||||
"lint-staged": "lint-staged",
|
"lint-staged": "lint-staged",
|
||||||
"stylelint-staged": "stylelint --syntax=scss"
|
"stylelint-staged": "stylelint --syntax=scss"
|
||||||
},
|
},
|
||||||
|
|
4
public/assets/bower/Autolinker.min.js
vendored
4
public/assets/bower/Autolinker.min.js
vendored
File diff suppressed because one or more lines are too long
BIN
public/assets/bower/Autolinker.min.js.br
Normal file
BIN
public/assets/bower/Autolinker.min.js.br
Normal file
Binary file not shown.
BIN
public/assets/bower/Autolinker.min.js.gz
Normal file
BIN
public/assets/bower/Autolinker.min.js.gz
Normal file
Binary file not shown.
|
@ -5,6 +5,21 @@
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var support = {
|
||||||
|
searchParams: 'URLSearchParams' in self,
|
||||||
|
iterable: 'Symbol' in self && 'iterator' in Symbol,
|
||||||
|
blob: 'FileReader' in self && 'Blob' in self && (function() {
|
||||||
|
try {
|
||||||
|
new Blob()
|
||||||
|
return true
|
||||||
|
} catch(e) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
})(),
|
||||||
|
formData: 'FormData' in self,
|
||||||
|
arrayBuffer: 'ArrayBuffer' in self
|
||||||
|
}
|
||||||
|
|
||||||
function normalizeName(name) {
|
function normalizeName(name) {
|
||||||
if (typeof name !== 'string') {
|
if (typeof name !== 'string') {
|
||||||
name = String(name)
|
name = String(name)
|
||||||
|
@ -22,6 +37,24 @@
|
||||||
return value
|
return value
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Build a destructive iterator for the value list
|
||||||
|
function iteratorFor(items) {
|
||||||
|
var iterator = {
|
||||||
|
next: function() {
|
||||||
|
var value = items.shift()
|
||||||
|
return {done: value === undefined, value: value}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (support.iterable) {
|
||||||
|
iterator[Symbol.iterator] = function() {
|
||||||
|
return iterator
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return iterator
|
||||||
|
}
|
||||||
|
|
||||||
function Headers(headers) {
|
function Headers(headers) {
|
||||||
this.map = {}
|
this.map = {}
|
||||||
|
|
||||||
|
@ -77,6 +110,28 @@
|
||||||
}, this)
|
}, this)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Headers.prototype.keys = function() {
|
||||||
|
var items = []
|
||||||
|
this.forEach(function(value, name) { items.push(name) })
|
||||||
|
return iteratorFor(items)
|
||||||
|
}
|
||||||
|
|
||||||
|
Headers.prototype.values = function() {
|
||||||
|
var items = []
|
||||||
|
this.forEach(function(value) { items.push(value) })
|
||||||
|
return iteratorFor(items)
|
||||||
|
}
|
||||||
|
|
||||||
|
Headers.prototype.entries = function() {
|
||||||
|
var items = []
|
||||||
|
this.forEach(function(value, name) { items.push([name, value]) })
|
||||||
|
return iteratorFor(items)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (support.iterable) {
|
||||||
|
Headers.prototype[Symbol.iterator] = Headers.prototype.entries
|
||||||
|
}
|
||||||
|
|
||||||
function consumed(body) {
|
function consumed(body) {
|
||||||
if (body.bodyUsed) {
|
if (body.bodyUsed) {
|
||||||
return Promise.reject(new TypeError('Already read'))
|
return Promise.reject(new TypeError('Already read'))
|
||||||
|
@ -107,23 +162,9 @@
|
||||||
return fileReaderReady(reader)
|
return fileReaderReady(reader)
|
||||||
}
|
}
|
||||||
|
|
||||||
var support = {
|
|
||||||
blob: 'FileReader' in self && 'Blob' in self && (function() {
|
|
||||||
try {
|
|
||||||
new Blob()
|
|
||||||
return true
|
|
||||||
} catch(e) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
})(),
|
|
||||||
formData: 'FormData' in self,
|
|
||||||
arrayBuffer: 'ArrayBuffer' in self
|
|
||||||
}
|
|
||||||
|
|
||||||
function Body() {
|
function Body() {
|
||||||
this.bodyUsed = false
|
this.bodyUsed = false
|
||||||
|
|
||||||
|
|
||||||
this._initBody = function(body) {
|
this._initBody = function(body) {
|
||||||
this._bodyInit = body
|
this._bodyInit = body
|
||||||
if (typeof body === 'string') {
|
if (typeof body === 'string') {
|
||||||
|
@ -132,6 +173,8 @@
|
||||||
this._bodyBlob = body
|
this._bodyBlob = body
|
||||||
} else if (support.formData && FormData.prototype.isPrototypeOf(body)) {
|
} else if (support.formData && FormData.prototype.isPrototypeOf(body)) {
|
||||||
this._bodyFormData = body
|
this._bodyFormData = body
|
||||||
|
} else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {
|
||||||
|
this._bodyText = body.toString()
|
||||||
} else if (!body) {
|
} else if (!body) {
|
||||||
this._bodyText = ''
|
this._bodyText = ''
|
||||||
} else if (support.arrayBuffer && ArrayBuffer.prototype.isPrototypeOf(body)) {
|
} else if (support.arrayBuffer && ArrayBuffer.prototype.isPrototypeOf(body)) {
|
||||||
|
@ -146,6 +189,8 @@
|
||||||
this.headers.set('content-type', 'text/plain;charset=UTF-8')
|
this.headers.set('content-type', 'text/plain;charset=UTF-8')
|
||||||
} else if (this._bodyBlob && this._bodyBlob.type) {
|
} else if (this._bodyBlob && this._bodyBlob.type) {
|
||||||
this.headers.set('content-type', this._bodyBlob.type)
|
this.headers.set('content-type', this._bodyBlob.type)
|
||||||
|
} else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {
|
||||||
|
this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -349,13 +394,8 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
xhr.onload = function() {
|
xhr.onload = function() {
|
||||||
var status = (xhr.status === 1223) ? 204 : xhr.status
|
|
||||||
if (status < 100 || status > 599) {
|
|
||||||
reject(new TypeError('Network request failed'))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
var options = {
|
var options = {
|
||||||
status: status,
|
status: xhr.status,
|
||||||
statusText: xhr.statusText,
|
statusText: xhr.statusText,
|
||||||
headers: headers(xhr),
|
headers: headers(xhr),
|
||||||
url: responseURL()
|
url: responseURL()
|
||||||
|
|
BIN
public/assets/bower/fetch.js.br
Normal file
BIN
public/assets/bower/fetch.js.br
Normal file
Binary file not shown.
BIN
public/assets/bower/fetch.js.gz
Normal file
BIN
public/assets/bower/fetch.js.gz
Normal file
Binary file not shown.
767
public/assets/bower/sanitize.css
vendored
767
public/assets/bower/sanitize.css
vendored
|
@ -1,263 +1,266 @@
|
||||||
/*! sanitize.css v3.3.0 | CC0 1.0 Public Domain | github.com/10up/sanitize.css */
|
/*! sanitize.css v4.1.0 | CC0 License | github.com/jonathantneal/sanitize.css */
|
||||||
|
|
||||||
/* Latest tested: Android 6, Chrome 48, Edge 13, Firefox 44, Internet Explorer 11, iOS 9, Opera 35, Safari 9, Windows Phone 8.1 */
|
/* Display definitions
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Normalization
|
* Add the correct display in IE 9-.
|
||||||
|
* 1. Add the correct display in Edge, IE, and Firefox.
|
||||||
|
* 2. Add the correct display in IE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
article,
|
||||||
|
aside,
|
||||||
|
details, /* 1 */
|
||||||
|
figcaption,
|
||||||
|
figure,
|
||||||
|
footer,
|
||||||
|
header,
|
||||||
|
main, /* 2 */
|
||||||
|
menu,
|
||||||
|
nav,
|
||||||
|
section,
|
||||||
|
summary { /* 1 */
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the correct display in IE 9-.
|
||||||
|
*/
|
||||||
|
|
||||||
|
audio,
|
||||||
|
canvas,
|
||||||
|
progress,
|
||||||
|
video {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the correct display in iOS 4-7.
|
||||||
|
*/
|
||||||
|
|
||||||
|
audio:not([controls]) {
|
||||||
|
display: none;
|
||||||
|
height: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the correct display in IE 10-.
|
||||||
|
* 1. Add the correct display in IE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
template, /* 1 */
|
||||||
|
[hidden] {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Elements of HTML (https://www.w3.org/TR/html5/semantics.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Remove repeating backgrounds in all browsers (opinionated).
|
||||||
|
* 2. Add box sizing inheritence in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
*,
|
||||||
|
::before,
|
||||||
|
::after {
|
||||||
|
background-repeat: no-repeat; /* 1 */
|
||||||
|
box-sizing: inherit; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Add text decoration inheritance in all browsers (opinionated).
|
||||||
|
* 2. Add vertical alignment inheritence in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
::before,
|
||||||
|
::after {
|
||||||
|
text-decoration: inherit; /* 1 */
|
||||||
|
vertical-align: inherit; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Add border box sizing in all browsers (opinionated).
|
||||||
|
* 2. Add the default cursor in all browsers (opinionated).
|
||||||
|
* 3. Add a flattened line height in all browsers (opinionated).
|
||||||
|
* 4. Prevent font size adjustments after orientation changes in IE and iOS.
|
||||||
|
*/
|
||||||
|
|
||||||
|
html {
|
||||||
|
box-sizing: border-box; /* 1 */
|
||||||
|
cursor: default; /* 2 */
|
||||||
|
font-family: sans-serif; /* 3 */
|
||||||
|
line-height: 1.5; /* 3 */
|
||||||
|
-ms-text-size-adjust: 100%; /* 4 */
|
||||||
|
-webkit-text-size-adjust: 100%; /* 5 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Sections (https://www.w3.org/TR/html5/sections.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the margin in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Correct the font sizes and margins on `h1` elements within
|
||||||
|
* `section` and `article` contexts in Chrome, Firefox, and Safari.
|
||||||
|
*/
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 2em;
|
||||||
|
margin: .67em 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Grouping content (https://www.w3.org/TR/html5/grouping-content.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Correct font sizing inheritance and scaling in all browsers.
|
||||||
|
* 2. Correct the odd `em` font sizing in all browsers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
code,
|
||||||
|
kbd,
|
||||||
|
pre,
|
||||||
|
samp {
|
||||||
|
font-family: monospace, monospace; /* 1 */
|
||||||
|
font-size: 1em; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Correct the height in Firefox.
|
||||||
|
* 2. Add visible overflow in Edge and IE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
hr {
|
||||||
|
height: 0; /* 1 */
|
||||||
|
overflow: visible; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the list style on navigation lists in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
nav ol,
|
||||||
|
nav ul {
|
||||||
|
list-style: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Text-level semantics
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Add a bordered underline effect in all browsers.
|
||||||
|
* 2. Remove text decoration in Firefox 40+.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
abbr[title] {
|
abbr[title] {
|
||||||
text-decoration: underline; /* Chrome 48+, Edge 12+, Internet Explorer 11-, Safari 9+ */
|
border-bottom: 1px dotted; /* 1 */
|
||||||
text-decoration: underline dotted; /* Firefox 40+ */
|
text-decoration: none; /* 2 */
|
||||||
}
|
}
|
||||||
|
|
||||||
audio:not([controls]) {
|
/**
|
||||||
display: none; /* Chrome 44-, iOS 8+, Safari 9+ */
|
* Prevent the duplicate application of `bolder` by the next rule in Safari 6.
|
||||||
}
|
*/
|
||||||
|
|
||||||
b,
|
b,
|
||||||
strong {
|
strong {
|
||||||
font-weight: bolder; /* Edge 12+, Safari 6.2+, and Chrome 18+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
button {
|
|
||||||
-webkit-appearance: button; /* iOS 8+ */
|
|
||||||
overflow: visible; /* Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
input {
|
|
||||||
}
|
|
||||||
|
|
||||||
button::-moz-focus-inner, input::-moz-focus-inner {
|
|
||||||
border: 0;/* Firefox 4+ */
|
|
||||||
padding: 0;/* Firefox 4+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
button:-moz-focusring, input:-moz-focusring {
|
|
||||||
outline: 1px dotted ButtonText;/* Firefox 4+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
select {
|
|
||||||
text-transform: none; /* Firefox 40+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
details {
|
|
||||||
display: block; /* Edge 12+, Firefox 40+, Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
html {
|
|
||||||
-ms-overflow-style: -ms-autohiding-scrollbar; /* Edge 12+, Internet Explorer 11- */
|
|
||||||
overflow-y: scroll; /* All browsers without overlaying scrollbars */
|
|
||||||
-webkit-text-size-adjust: 100%; /* iOS 8+, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
hr {
|
|
||||||
overflow: visible; /* Internet Explorer 11-, Edge 12+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input {
|
|
||||||
-webkit-border-radius: 0 /* iOS 8+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="button"],
|
|
||||||
input[type="reset"],
|
|
||||||
input[type="submit"] {
|
|
||||||
-webkit-appearance: button;/* iOS 8+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="number"] {
|
|
||||||
width: auto;/* Firefox 36+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="search"] {
|
|
||||||
-webkit-appearance: textfield;/* Chrome 45+, Safari 9+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="search"]::-webkit-search-cancel-button,
|
|
||||||
input[type="search"]::-webkit-search-decoration {
|
|
||||||
-webkit-appearance: none;/* Chrome 45+, Safari 9+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
main {
|
|
||||||
display: block; /* Android 4.3-, Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
pre {
|
|
||||||
overflow: auto; /* Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
progress {
|
|
||||||
display: inline-block; /* Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
summary {
|
|
||||||
display: block; /* Firefox 40+, Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
svg:not(:root) {
|
|
||||||
overflow: hidden; /* Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
template {
|
|
||||||
display: none; /* Android 4.3-, Internet Explorer 11-, iOS 7-, Safari 7-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
textarea {
|
|
||||||
overflow: auto; /* Edge 12+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
[hidden] {
|
|
||||||
display: none; /* Internet Explorer 10- */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Universal inheritance
|
|
||||||
*/
|
|
||||||
|
|
||||||
*,
|
|
||||||
:before,
|
|
||||||
:after {
|
|
||||||
box-sizing: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
* {
|
|
||||||
font-size: inherit;
|
|
||||||
line-height: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
:before,
|
|
||||||
:after {
|
|
||||||
text-decoration: inherit;
|
|
||||||
vertical-align: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
input,
|
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
font-family: inherit;
|
|
||||||
font-style: inherit;
|
|
||||||
font-weight: inherit;
|
font-weight: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the correct font weight in Chrome, Edge, and Safari.
|
||||||
/*
|
|
||||||
* Opinionated defaults
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* specify the margin and padding of all elements */
|
b,
|
||||||
|
strong {
|
||||||
* {
|
font-weight: bolder;
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the border style and width of all elements */
|
/**
|
||||||
|
* Add the correct font style in Android 4.3-.
|
||||||
*,
|
|
||||||
:before,
|
|
||||||
:after {
|
|
||||||
border-style: solid;
|
|
||||||
border-width: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* remove the tapping delay from clickable elements */
|
|
||||||
|
|
||||||
a,
|
|
||||||
area,
|
|
||||||
button,
|
|
||||||
input,
|
|
||||||
label,
|
|
||||||
select,
|
|
||||||
textarea,
|
|
||||||
[tabindex] {
|
|
||||||
-ms-touch-action: manipulation;
|
|
||||||
touch-action: manipulation;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the standard appearance of selects */
|
|
||||||
|
|
||||||
select {
|
|
||||||
-moz-appearance: none; /* Firefox 40+ */
|
|
||||||
-webkit-appearance: none /* Chrome 45+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
select::-ms-expand {
|
|
||||||
display: none;/* Edge 12+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
select::-ms-value {
|
|
||||||
color: currentColor;/* Edge 12+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* use current current as the default fill of svg elements */
|
|
||||||
|
|
||||||
svg {
|
|
||||||
fill: currentColor;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the progress cursor of updating elements */
|
|
||||||
|
|
||||||
[aria-busy="true"] {
|
|
||||||
cursor: progress;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the pointer cursor of trigger elements */
|
|
||||||
|
|
||||||
[aria-controls] {
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
|
|
||||||
|
|
||||||
[aria-disabled] {
|
|
||||||
cursor: default;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the style of visually hidden yet accessible elements */
|
|
||||||
|
|
||||||
[hidden][aria-hidden="false"] {
|
|
||||||
clip: rect(0 0 0 0);
|
|
||||||
display: inherit;
|
|
||||||
position: absolute
|
|
||||||
}
|
|
||||||
|
|
||||||
[hidden][aria-hidden="false"]:focus {
|
|
||||||
clip: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Configurable defaults
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* specify the background repeat of all elements */
|
dfn {
|
||||||
|
font-style: italic;
|
||||||
* {
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the root styles of the document */
|
/**
|
||||||
|
* Add the correct colors in IE 9-.
|
||||||
|
*/
|
||||||
|
|
||||||
:root {
|
mark {
|
||||||
background-color: #ffffff;
|
background-color: #ffff00;
|
||||||
box-sizing: border-box;
|
|
||||||
color: #000000;
|
color: #000000;
|
||||||
cursor: default;
|
|
||||||
font: 100%/1.5 sans-serif;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the text decoration of anchors */
|
/**
|
||||||
|
* Add the correct vertical alignment in Chrome, Firefox, and Opera.
|
||||||
|
*/
|
||||||
|
|
||||||
a {
|
progress {
|
||||||
text-decoration: none;
|
vertical-align: baseline;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the alignment of media elements */
|
/**
|
||||||
|
* Correct the font size in all browsers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
small {
|
||||||
|
font-size: 83.3333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the positioning on superscript and subscript elements
|
||||||
|
* in all browsers (opinionated).
|
||||||
|
* 1. Correct the font size in all browsers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
sub,
|
||||||
|
sup {
|
||||||
|
font-size: 83.3333%; /* 1 */
|
||||||
|
line-height: 0;
|
||||||
|
position: relative;
|
||||||
|
vertical-align: baseline;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub {
|
||||||
|
bottom: -.25em;
|
||||||
|
}
|
||||||
|
|
||||||
|
sup {
|
||||||
|
top: -.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove the text shadow on text selections (opinionated).
|
||||||
|
* 1. Restore the coloring undone by defining the text shadow (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
::-moz-selection {
|
||||||
|
background-color: #b3d4fc; /* 1 */
|
||||||
|
color: #000000; /* 1 */
|
||||||
|
text-shadow: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
::selection {
|
||||||
|
background-color: #b3d4fc; /* 1 */
|
||||||
|
color: #000000; /* 1 */
|
||||||
|
text-shadow: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Embedded content (https://www.w3.org/TR/html5/embedded-content-0.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Change the alignment on media elements in all browers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
audio,
|
audio,
|
||||||
canvas,
|
canvas,
|
||||||
|
@ -268,85 +271,279 @@ video {
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the coloring of form elements */
|
/**
|
||||||
|
* Remove the border on images inside links in IE 10-.
|
||||||
|
*/
|
||||||
|
|
||||||
button,
|
img {
|
||||||
input,
|
border-style: none;
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
background-color: transparent;
|
|
||||||
color: inherit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the minimum height of form elements */
|
/**
|
||||||
|
* Change the fill color to match the text color in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
button,
|
svg {
|
||||||
[type="button"],
|
fill: currentColor;
|
||||||
[type="date"],
|
|
||||||
[type="datetime"],
|
|
||||||
[type="datetime-local"],
|
|
||||||
[type="email"],
|
|
||||||
[type="month"],
|
|
||||||
[type="number"],
|
|
||||||
[type="password"],
|
|
||||||
[type="reset"],
|
|
||||||
[type="search"],
|
|
||||||
[type="submit"],
|
|
||||||
[type="tel"],
|
|
||||||
[type="text"],
|
|
||||||
[type="time"],
|
|
||||||
[type="url"],
|
|
||||||
[type="week"],
|
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
min-height: 1.5em;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the font family of code elements */
|
/**
|
||||||
|
* Hide the overflow in IE.
|
||||||
|
*/
|
||||||
|
|
||||||
code,
|
svg:not(:root) {
|
||||||
kbd,
|
overflow: hidden;
|
||||||
pre,
|
|
||||||
samp {
|
|
||||||
font-family: monospace, monospace;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the list style of nav lists */
|
/* Links (https://www.w3.org/TR/html5/links.html#links)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
nav ol,
|
/**
|
||||||
nav ul {
|
* 1. Remove the gray background on active links in IE 10.
|
||||||
list-style: none;
|
* 2. Remove the gaps in underlines in iOS 8+ and Safari 8+.
|
||||||
|
*/
|
||||||
|
|
||||||
|
a {
|
||||||
|
background-color: transparent; /* 1 */
|
||||||
|
-webkit-text-decoration-skip: objects; /* 2 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the font size of small elements */
|
/**
|
||||||
|
* Remove the outline when hovering in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
small {
|
a:hover {
|
||||||
font-size: 75%;
|
outline-width: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the border styling of tables */
|
/* Tabular data (https://www.w3.org/TR/html5/tabular-data.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove border spacing in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
table {
|
table {
|
||||||
border-collapse: collapse;
|
border-collapse: collapse;
|
||||||
border-spacing: 0;
|
border-spacing: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the resizability of textareas */
|
/* transform-style: (https://www.w3.org/TR/html5/forms.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Remove the default styling in all browsers (opinionated).
|
||||||
|
* 3. Remove the margin in Firefox and Safari.
|
||||||
|
*/
|
||||||
|
|
||||||
|
button,
|
||||||
|
input,
|
||||||
|
select,
|
||||||
|
textarea {
|
||||||
|
background-color: transparent; /* 1 */
|
||||||
|
border-style: none; /* 1 */
|
||||||
|
color: inherit; /* 1 */
|
||||||
|
font-size: 1em; /* 1 */
|
||||||
|
margin: 0; /* 3 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Correct the overflow in IE.
|
||||||
|
* 1. Correct the overflow in Edge.
|
||||||
|
*/
|
||||||
|
|
||||||
|
button,
|
||||||
|
input { /* 1 */
|
||||||
|
overflow: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the inheritance in Edge, Firefox, and IE.
|
||||||
|
* 1. Remove the inheritance in Firefox.
|
||||||
|
*/
|
||||||
|
|
||||||
|
button,
|
||||||
|
select { /* 1 */
|
||||||
|
text-transform: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Prevent the WebKit bug where (2) destroys native `audio` and `video`
|
||||||
|
* controls in Android 4.
|
||||||
|
* 2. Correct the inability to style clickable types in iOS and Safari.
|
||||||
|
*/
|
||||||
|
|
||||||
|
button,
|
||||||
|
html [type="button"], /* 1 */
|
||||||
|
[type="reset"],
|
||||||
|
[type="submit"] {
|
||||||
|
-webkit-appearance: button; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the inner border and padding in Firefox.
|
||||||
|
*/
|
||||||
|
|
||||||
|
::-moz-focus-inner {
|
||||||
|
border-style: none;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Correct the focus styles unset by the previous rule.
|
||||||
|
*/
|
||||||
|
|
||||||
|
:-moz-focusring {
|
||||||
|
outline: 1px dotted ButtonText;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Correct the border, margin, and padding in all browsers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
fieldset {
|
||||||
|
border: 1px solid #c0c0c0;
|
||||||
|
margin: 0 2px;
|
||||||
|
padding: .35em .625em .75em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Correct the text wrapping in Edge and IE.
|
||||||
|
* 2. Remove the padding so developers are not caught out when they zero out
|
||||||
|
* `fieldset` elements in all browsers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
legend {
|
||||||
|
display: table; /* 1 */
|
||||||
|
max-width: 100%; /* 1 */
|
||||||
|
padding: 0; /* 2 */
|
||||||
|
white-space: normal; /* 1 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Remove the vertical scrollbar in IE.
|
||||||
|
* 2. Change the resize direction on textareas in all browsers (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
textarea {
|
textarea {
|
||||||
resize: vertical;
|
overflow: auto; /* 1 */
|
||||||
|
resize: vertical; /* 2 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* specify the background color, font color, and drop shadow of text selections */
|
/**
|
||||||
|
* Remove the padding in IE 10-.
|
||||||
|
*/
|
||||||
|
|
||||||
::-moz-selection {
|
[type="checkbox"],
|
||||||
background-color: #b3d4fc; /* required when declaring ::selection */
|
[type="radio"] {
|
||||||
color: #ffffff;
|
padding: 0;
|
||||||
text-shadow: none;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
::selection {
|
/**
|
||||||
background-color: #b3d4fc; /* required when declaring ::selection */
|
* Correct the cursor style on increment and decrement buttons in Chrome.
|
||||||
color: #ffffff;
|
*/
|
||||||
text-shadow: none;
|
|
||||||
|
::-webkit-inner-spin-button,
|
||||||
|
::-webkit-outer-spin-button {
|
||||||
|
height: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Correct the odd appearance in Chrome and Safari.
|
||||||
|
* 2. Correct the outline style in Safari.
|
||||||
|
*/
|
||||||
|
|
||||||
|
[type="search"] {
|
||||||
|
-webkit-appearance: textfield; /* 1 */
|
||||||
|
outline-offset: -2px; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the inner padding and cancel buttons in Chrome and Safari for OS X.
|
||||||
|
*/
|
||||||
|
|
||||||
|
::-webkit-search-cancel-button,
|
||||||
|
::-webkit-search-decoration {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Correct the text style on placeholders in Chrome, Edge, and Safari.
|
||||||
|
*/
|
||||||
|
|
||||||
|
::-webkit-input-placeholder {
|
||||||
|
color: inherit;
|
||||||
|
opacity: .54;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Correct the inability to style clickable types in iOS and Safari.
|
||||||
|
* 2. Change font properties to `inherit` in Safari.
|
||||||
|
*/
|
||||||
|
|
||||||
|
::-webkit-file-upload-button {
|
||||||
|
-webkit-appearance: button; /* 1 */
|
||||||
|
font: inherit; /* 2 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* WAI-ARIA (https://www.w3.org/TR/html5/dom.html#wai-aria)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the cursor on busy elements (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
[aria-busy="true"] {
|
||||||
|
cursor: progress;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Change the cursor on control elements (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
[aria-controls] {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Change the cursor on disabled, not-editable, or otherwise
|
||||||
|
* inoperable elements (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
[aria-disabled] {
|
||||||
|
cursor: default;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* User interaction (https://www.w3.org/TR/html5/editing.html)
|
||||||
|
========================================================================== */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove the tapping delay on clickable elements (opinionated).
|
||||||
|
* 1. Remove the tapping delay in IE 10.
|
||||||
|
*/
|
||||||
|
|
||||||
|
a,
|
||||||
|
area,
|
||||||
|
button,
|
||||||
|
input,
|
||||||
|
label,
|
||||||
|
select,
|
||||||
|
textarea,
|
||||||
|
[tabindex] {
|
||||||
|
-ms-touch-action: manipulation; /* 1 */
|
||||||
|
touch-action: manipulation;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Change the display on visually hidden accessible elements (opinionated).
|
||||||
|
*/
|
||||||
|
|
||||||
|
[hidden][aria-hidden="false"] {
|
||||||
|
clip: rect(0, 0, 0, 0);
|
||||||
|
display: inherit;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
|
||||||
|
[hidden][aria-hidden="false"]:focus {
|
||||||
|
clip: auto;
|
||||||
}
|
}
|
||||||
|
|
BIN
public/assets/bower/sanitize.css.br
Normal file
BIN
public/assets/bower/sanitize.css.br
Normal file
Binary file not shown.
BIN
public/assets/bower/sanitize.css.gz
Normal file
BIN
public/assets/bower/sanitize.css.gz
Normal file
Binary file not shown.
6
public/assets/css/global.css
vendored
6
public/assets/css/global.css
vendored
|
@ -13,7 +13,6 @@ html {
|
||||||
box-sizing: inherit; }
|
box-sizing: inherit; }
|
||||||
|
|
||||||
#topheader {
|
#topheader {
|
||||||
display: -webkit-box;
|
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-flow: row; }
|
flex-flow: row; }
|
||||||
|
|
||||||
|
@ -156,7 +155,6 @@ article header {
|
||||||
|
|
||||||
body {
|
body {
|
||||||
text-rendering: optimizeLegibility;
|
text-rendering: optimizeLegibility;
|
||||||
-webkit-font-feature-settings: "liga";
|
|
||||||
font-feature-settings: "liga";
|
font-feature-settings: "liga";
|
||||||
font-family: "leitura-news", serif;
|
font-family: "leitura-news", serif;
|
||||||
font-size: 1.2em; }
|
font-size: 1.2em; }
|
||||||
|
@ -171,7 +169,6 @@ h1 {
|
||||||
text-decoration: none; }
|
text-decoration: none; }
|
||||||
|
|
||||||
nav {
|
nav {
|
||||||
-webkit-font-feature-settings: "dlig";
|
|
||||||
font-feature-settings: "dlig"; }
|
font-feature-settings: "dlig"; }
|
||||||
|
|
||||||
article header h1 a {
|
article header h1 a {
|
||||||
|
@ -219,7 +216,6 @@ textarea {
|
||||||
border-radius: 4px; }
|
border-radius: 4px; }
|
||||||
|
|
||||||
button:hover {
|
button:hover {
|
||||||
-webkit-transition: 0.5s ease-in-out;
|
|
||||||
transition: 0.5s ease-in-out;
|
transition: 0.5s ease-in-out;
|
||||||
background-color: #fdf6e3;
|
background-color: #fdf6e3;
|
||||||
color: #002b36; }
|
color: #002b36; }
|
||||||
|
@ -242,5 +238,3 @@ input[type="checkbox"] {
|
||||||
|
|
||||||
.twitter-tweet-rendered + .note {
|
.twitter-tweet-rendered + .note {
|
||||||
margin-top: 0; }
|
margin-top: 0; }
|
||||||
|
|
||||||
/*# sourceMappingURL=global.css.map */
|
|
||||||
|
|
BIN
public/assets/css/global.css.br
Normal file
BIN
public/assets/css/global.css.br
Normal file
Binary file not shown.
BIN
public/assets/css/global.css.gz
Normal file
BIN
public/assets/css/global.css.gz
Normal file
Binary file not shown.
File diff suppressed because one or more lines are too long
Binary file not shown.
Binary file not shown.
|
@ -1 +0,0 @@
|
||||||
.alertify-logs>*{padding:12px 24px;color:#fff;box-shadow:0 2px 5px 0 rgba(0,0,0,.2);border-radius:1px}.alertify-logs>*,.alertify-logs>.default{background:rgba(0,0,0,.8)}.alertify-logs>.error{background:rgba(244,67,54,.8)}.alertify-logs>.success{background:rgba(76,175,80,.9)}.alertify{position:fixed;background-color:rgba(0,0,0,.3);left:0;right:0;top:0;bottom:0;width:100%;height:100%;z-index:1}.alertify.hide{opacity:0;pointer-events:none}.alertify,.alertify.show{box-sizing:border-box;transition:all .33s cubic-bezier(.25,.8,.25,1)}.alertify,.alertify *{box-sizing:border-box}.alertify .dialog{padding:12px}.alertify .alert,.alertify .dialog{width:100%;margin:0 auto;position:relative;top:50%;transform:translateY(-50%)}.alertify .alert>*,.alertify .dialog>*{width:400px;max-width:95%;margin:0 auto;text-align:center;padding:12px;background:#fff;box-shadow:0 2px 4px -1px rgba(0,0,0,.14),0 4px 5px 0 rgba(0,0,0,.098),0 1px 10px 0 rgba(0,0,0,.084)}.alertify .alert .msg,.alertify .dialog .msg{padding:12px;margin-bottom:12px;margin:0;text-align:left}.alertify .alert input:not(.form-control),.alertify .dialog input:not(.form-control){margin-bottom:15px;width:100%;font-size:100%;padding:12px}.alertify .alert input:not(.form-control):focus,.alertify .dialog input:not(.form-control):focus{outline-offset:-2px}.alertify .alert nav,.alertify .dialog nav{text-align:right}.alertify .alert nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button),.alertify .dialog nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button){background:transparent;box-sizing:border-box;color:rgba(0,0,0,.87);position:relative;outline:0;border:0;display:inline-block;-ms-flex-align:center;-ms-grid-row-align:center;align-items:center;padding:0 6px;margin:6px 8px;line-height:36px;min-height:36px;white-space:nowrap;min-width:88px;text-align:center;text-transform:uppercase;font-size:14px;text-decoration:none;cursor:pointer;border:1px solid transparent;border-radius:2px}.alertify .alert nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button):active,.alertify .alert nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button):hover,.alertify .dialog nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button):active,.alertify .dialog nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button):hover{background-color:rgba(0,0,0,.05)}.alertify .alert nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button):focus,.alertify .dialog nav button:not(.btn):not(.pure-button):not(.md-button):not(.mdl-button):focus{border:1px solid rgba(0,0,0,.1)}.alertify .alert nav button.btn,.alertify .dialog nav button.btn{margin:6px 4px}.alertify-logs{position:fixed;z-index:1}.alertify-logs.bottom,.alertify-logs:not(.top){bottom:16px}.alertify-logs.left,.alertify-logs:not(.right){left:16px}.alertify-logs.left>*,.alertify-logs:not(.right)>*{float:left;transform:translateZ(0);height:auto}.alertify-logs.left>.show,.alertify-logs:not(.right)>.show{left:0}.alertify-logs.left>*,.alertify-logs.left>.hide,.alertify-logs:not(.right)>*,.alertify-logs:not(.right)>.hide{left:-110%}.alertify-logs.right{right:16px}.alertify-logs.right>*{float:right;transform:translateZ(0)}.alertify-logs.right>.show{right:0;opacity:1}.alertify-logs.right>*,.alertify-logs.right>.hide{right:-110%;opacity:0}.alertify-logs.top{top:0}.alertify-logs>*{box-sizing:border-box;transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;clear:both;backface-visibility:hidden;perspective:1000;max-height:0;margin:0;padding:0;overflow:hidden;opacity:0;pointer-events:none}.alertify-logs>.show{margin-top:12px;opacity:1;max-height:1000px;padding:12px;pointer-events:auto}
|
|
File diff suppressed because one or more lines are too long
|
@ -1,393 +0,0 @@
|
||||||
(function(self) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
if (self.fetch) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
function normalizeName(name) {
|
|
||||||
if (typeof name !== 'string') {
|
|
||||||
name = String(name)
|
|
||||||
}
|
|
||||||
if (/[^a-z0-9\-#$%&'*+.\^_`|~]/i.test(name)) {
|
|
||||||
throw new TypeError('Invalid character in header field name')
|
|
||||||
}
|
|
||||||
return name.toLowerCase()
|
|
||||||
}
|
|
||||||
|
|
||||||
function normalizeValue(value) {
|
|
||||||
if (typeof value !== 'string') {
|
|
||||||
value = String(value)
|
|
||||||
}
|
|
||||||
return value
|
|
||||||
}
|
|
||||||
|
|
||||||
function Headers(headers) {
|
|
||||||
this.map = {}
|
|
||||||
|
|
||||||
if (headers instanceof Headers) {
|
|
||||||
headers.forEach(function(value, name) {
|
|
||||||
this.append(name, value)
|
|
||||||
}, this)
|
|
||||||
|
|
||||||
} else if (headers) {
|
|
||||||
Object.getOwnPropertyNames(headers).forEach(function(name) {
|
|
||||||
this.append(name, headers[name])
|
|
||||||
}, this)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype.append = function(name, value) {
|
|
||||||
name = normalizeName(name)
|
|
||||||
value = normalizeValue(value)
|
|
||||||
var list = this.map[name]
|
|
||||||
if (!list) {
|
|
||||||
list = []
|
|
||||||
this.map[name] = list
|
|
||||||
}
|
|
||||||
list.push(value)
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype['delete'] = function(name) {
|
|
||||||
delete this.map[normalizeName(name)]
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype.get = function(name) {
|
|
||||||
var values = this.map[normalizeName(name)]
|
|
||||||
return values ? values[0] : null
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype.getAll = function(name) {
|
|
||||||
return this.map[normalizeName(name)] || []
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype.has = function(name) {
|
|
||||||
return this.map.hasOwnProperty(normalizeName(name))
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype.set = function(name, value) {
|
|
||||||
this.map[normalizeName(name)] = [normalizeValue(value)]
|
|
||||||
}
|
|
||||||
|
|
||||||
Headers.prototype.forEach = function(callback, thisArg) {
|
|
||||||
Object.getOwnPropertyNames(this.map).forEach(function(name) {
|
|
||||||
this.map[name].forEach(function(value) {
|
|
||||||
callback.call(thisArg, value, name, this)
|
|
||||||
}, this)
|
|
||||||
}, this)
|
|
||||||
}
|
|
||||||
|
|
||||||
function consumed(body) {
|
|
||||||
if (body.bodyUsed) {
|
|
||||||
return Promise.reject(new TypeError('Already read'))
|
|
||||||
}
|
|
||||||
body.bodyUsed = true
|
|
||||||
}
|
|
||||||
|
|
||||||
function fileReaderReady(reader) {
|
|
||||||
return new Promise(function(resolve, reject) {
|
|
||||||
reader.onload = function() {
|
|
||||||
resolve(reader.result)
|
|
||||||
}
|
|
||||||
reader.onerror = function() {
|
|
||||||
reject(reader.error)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
function readBlobAsArrayBuffer(blob) {
|
|
||||||
var reader = new FileReader()
|
|
||||||
reader.readAsArrayBuffer(blob)
|
|
||||||
return fileReaderReady(reader)
|
|
||||||
}
|
|
||||||
|
|
||||||
function readBlobAsText(blob) {
|
|
||||||
var reader = new FileReader()
|
|
||||||
reader.readAsText(blob)
|
|
||||||
return fileReaderReady(reader)
|
|
||||||
}
|
|
||||||
|
|
||||||
var support = {
|
|
||||||
blob: 'FileReader' in self && 'Blob' in self && (function() {
|
|
||||||
try {
|
|
||||||
new Blob()
|
|
||||||
return true
|
|
||||||
} catch(e) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
})(),
|
|
||||||
formData: 'FormData' in self,
|
|
||||||
arrayBuffer: 'ArrayBuffer' in self
|
|
||||||
}
|
|
||||||
|
|
||||||
function Body() {
|
|
||||||
this.bodyUsed = false
|
|
||||||
|
|
||||||
|
|
||||||
this._initBody = function(body) {
|
|
||||||
this._bodyInit = body
|
|
||||||
if (typeof body === 'string') {
|
|
||||||
this._bodyText = body
|
|
||||||
} else if (support.blob && Blob.prototype.isPrototypeOf(body)) {
|
|
||||||
this._bodyBlob = body
|
|
||||||
} else if (support.formData && FormData.prototype.isPrototypeOf(body)) {
|
|
||||||
this._bodyFormData = body
|
|
||||||
} else if (!body) {
|
|
||||||
this._bodyText = ''
|
|
||||||
} else if (support.arrayBuffer && ArrayBuffer.prototype.isPrototypeOf(body)) {
|
|
||||||
// Only support ArrayBuffers for POST method.
|
|
||||||
// Receiving ArrayBuffers happens via Blobs, instead.
|
|
||||||
} else {
|
|
||||||
throw new Error('unsupported BodyInit type')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!this.headers.get('content-type')) {
|
|
||||||
if (typeof body === 'string') {
|
|
||||||
this.headers.set('content-type', 'text/plain;charset=UTF-8')
|
|
||||||
} else if (this._bodyBlob && this._bodyBlob.type) {
|
|
||||||
this.headers.set('content-type', this._bodyBlob.type)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (support.blob) {
|
|
||||||
this.blob = function() {
|
|
||||||
var rejected = consumed(this)
|
|
||||||
if (rejected) {
|
|
||||||
return rejected
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._bodyBlob) {
|
|
||||||
return Promise.resolve(this._bodyBlob)
|
|
||||||
} else if (this._bodyFormData) {
|
|
||||||
throw new Error('could not read FormData body as blob')
|
|
||||||
} else {
|
|
||||||
return Promise.resolve(new Blob([this._bodyText]))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.arrayBuffer = function() {
|
|
||||||
return this.blob().then(readBlobAsArrayBuffer)
|
|
||||||
}
|
|
||||||
|
|
||||||
this.text = function() {
|
|
||||||
var rejected = consumed(this)
|
|
||||||
if (rejected) {
|
|
||||||
return rejected
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._bodyBlob) {
|
|
||||||
return readBlobAsText(this._bodyBlob)
|
|
||||||
} else if (this._bodyFormData) {
|
|
||||||
throw new Error('could not read FormData body as text')
|
|
||||||
} else {
|
|
||||||
return Promise.resolve(this._bodyText)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
this.text = function() {
|
|
||||||
var rejected = consumed(this)
|
|
||||||
return rejected ? rejected : Promise.resolve(this._bodyText)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (support.formData) {
|
|
||||||
this.formData = function() {
|
|
||||||
return this.text().then(decode)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.json = function() {
|
|
||||||
return this.text().then(JSON.parse)
|
|
||||||
}
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
// HTTP methods whose capitalization should be normalized
|
|
||||||
var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT']
|
|
||||||
|
|
||||||
function normalizeMethod(method) {
|
|
||||||
var upcased = method.toUpperCase()
|
|
||||||
return (methods.indexOf(upcased) > -1) ? upcased : method
|
|
||||||
}
|
|
||||||
|
|
||||||
function Request(input, options) {
|
|
||||||
options = options || {}
|
|
||||||
var body = options.body
|
|
||||||
if (Request.prototype.isPrototypeOf(input)) {
|
|
||||||
if (input.bodyUsed) {
|
|
||||||
throw new TypeError('Already read')
|
|
||||||
}
|
|
||||||
this.url = input.url
|
|
||||||
this.credentials = input.credentials
|
|
||||||
if (!options.headers) {
|
|
||||||
this.headers = new Headers(input.headers)
|
|
||||||
}
|
|
||||||
this.method = input.method
|
|
||||||
this.mode = input.mode
|
|
||||||
if (!body) {
|
|
||||||
body = input._bodyInit
|
|
||||||
input.bodyUsed = true
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
this.url = input
|
|
||||||
}
|
|
||||||
|
|
||||||
this.credentials = options.credentials || this.credentials || 'omit'
|
|
||||||
if (options.headers || !this.headers) {
|
|
||||||
this.headers = new Headers(options.headers)
|
|
||||||
}
|
|
||||||
this.method = normalizeMethod(options.method || this.method || 'GET')
|
|
||||||
this.mode = options.mode || this.mode || null
|
|
||||||
this.referrer = null
|
|
||||||
|
|
||||||
if ((this.method === 'GET' || this.method === 'HEAD') && body) {
|
|
||||||
throw new TypeError('Body not allowed for GET or HEAD requests')
|
|
||||||
}
|
|
||||||
this._initBody(body)
|
|
||||||
}
|
|
||||||
|
|
||||||
Request.prototype.clone = function() {
|
|
||||||
return new Request(this)
|
|
||||||
}
|
|
||||||
|
|
||||||
function decode(body) {
|
|
||||||
var form = new FormData()
|
|
||||||
body.trim().split('&').forEach(function(bytes) {
|
|
||||||
if (bytes) {
|
|
||||||
var split = bytes.split('=')
|
|
||||||
var name = split.shift().replace(/\+/g, ' ')
|
|
||||||
var value = split.join('=').replace(/\+/g, ' ')
|
|
||||||
form.append(decodeURIComponent(name), decodeURIComponent(value))
|
|
||||||
}
|
|
||||||
})
|
|
||||||
return form
|
|
||||||
}
|
|
||||||
|
|
||||||
function headers(xhr) {
|
|
||||||
var head = new Headers()
|
|
||||||
var pairs = (xhr.getAllResponseHeaders() || '').trim().split('\n')
|
|
||||||
pairs.forEach(function(header) {
|
|
||||||
var split = header.trim().split(':')
|
|
||||||
var key = split.shift().trim()
|
|
||||||
var value = split.join(':').trim()
|
|
||||||
head.append(key, value)
|
|
||||||
})
|
|
||||||
return head
|
|
||||||
}
|
|
||||||
|
|
||||||
Body.call(Request.prototype)
|
|
||||||
|
|
||||||
function Response(bodyInit, options) {
|
|
||||||
if (!options) {
|
|
||||||
options = {}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.type = 'default'
|
|
||||||
this.status = options.status
|
|
||||||
this.ok = this.status >= 200 && this.status < 300
|
|
||||||
this.statusText = options.statusText
|
|
||||||
this.headers = options.headers instanceof Headers ? options.headers : new Headers(options.headers)
|
|
||||||
this.url = options.url || ''
|
|
||||||
this._initBody(bodyInit)
|
|
||||||
}
|
|
||||||
|
|
||||||
Body.call(Response.prototype)
|
|
||||||
|
|
||||||
Response.prototype.clone = function() {
|
|
||||||
return new Response(this._bodyInit, {
|
|
||||||
status: this.status,
|
|
||||||
statusText: this.statusText,
|
|
||||||
headers: new Headers(this.headers),
|
|
||||||
url: this.url
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
Response.error = function() {
|
|
||||||
var response = new Response(null, {status: 0, statusText: ''})
|
|
||||||
response.type = 'error'
|
|
||||||
return response
|
|
||||||
}
|
|
||||||
|
|
||||||
var redirectStatuses = [301, 302, 303, 307, 308]
|
|
||||||
|
|
||||||
Response.redirect = function(url, status) {
|
|
||||||
if (redirectStatuses.indexOf(status) === -1) {
|
|
||||||
throw new RangeError('Invalid status code')
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Response(null, {status: status, headers: {location: url}})
|
|
||||||
}
|
|
||||||
|
|
||||||
self.Headers = Headers
|
|
||||||
self.Request = Request
|
|
||||||
self.Response = Response
|
|
||||||
|
|
||||||
self.fetch = function(input, init) {
|
|
||||||
return new Promise(function(resolve, reject) {
|
|
||||||
var request
|
|
||||||
if (Request.prototype.isPrototypeOf(input) && !init) {
|
|
||||||
request = input
|
|
||||||
} else {
|
|
||||||
request = new Request(input, init)
|
|
||||||
}
|
|
||||||
|
|
||||||
var xhr = new XMLHttpRequest()
|
|
||||||
|
|
||||||
function responseURL() {
|
|
||||||
if ('responseURL' in xhr) {
|
|
||||||
return xhr.responseURL
|
|
||||||
}
|
|
||||||
|
|
||||||
// Avoid security warnings on getResponseHeader when not allowed by CORS
|
|
||||||
if (/^X-Request-URL:/m.test(xhr.getAllResponseHeaders())) {
|
|
||||||
return xhr.getResponseHeader('X-Request-URL')
|
|
||||||
}
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
xhr.onload = function() {
|
|
||||||
var status = (xhr.status === 1223) ? 204 : xhr.status
|
|
||||||
if (status < 100 || status > 599) {
|
|
||||||
reject(new TypeError('Network request failed'))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
var options = {
|
|
||||||
status: status,
|
|
||||||
statusText: xhr.statusText,
|
|
||||||
headers: headers(xhr),
|
|
||||||
url: responseURL()
|
|
||||||
}
|
|
||||||
var body = 'response' in xhr ? xhr.response : xhr.responseText
|
|
||||||
resolve(new Response(body, options))
|
|
||||||
}
|
|
||||||
|
|
||||||
xhr.onerror = function() {
|
|
||||||
reject(new TypeError('Network request failed'))
|
|
||||||
}
|
|
||||||
|
|
||||||
xhr.ontimeout = function() {
|
|
||||||
reject(new TypeError('Network request failed'))
|
|
||||||
}
|
|
||||||
|
|
||||||
xhr.open(request.method, request.url, true)
|
|
||||||
|
|
||||||
if (request.credentials === 'include') {
|
|
||||||
xhr.withCredentials = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if ('responseType' in xhr && support.blob) {
|
|
||||||
xhr.responseType = 'blob'
|
|
||||||
}
|
|
||||||
|
|
||||||
request.headers.forEach(function(value, name) {
|
|
||||||
xhr.setRequestHeader(name, value)
|
|
||||||
})
|
|
||||||
|
|
||||||
xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
self.fetch.polyfill = true
|
|
||||||
})(typeof self !== 'undefined' ? self : this);
|
|
Binary file not shown.
Binary file not shown.
File diff suppressed because one or more lines are too long
352
public/build/assets/bower/sanitize-85919f917a.css
vendored
352
public/build/assets/bower/sanitize-85919f917a.css
vendored
|
@ -1,352 +0,0 @@
|
||||||
/*! sanitize.css v3.3.0 | CC0 1.0 Public Domain | github.com/10up/sanitize.css */
|
|
||||||
|
|
||||||
/* Latest tested: Android 6, Chrome 48, Edge 13, Firefox 44, Internet Explorer 11, iOS 9, Opera 35, Safari 9, Windows Phone 8.1 */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Normalization
|
|
||||||
*/
|
|
||||||
|
|
||||||
abbr[title] {
|
|
||||||
text-decoration: underline; /* Chrome 48+, Edge 12+, Internet Explorer 11-, Safari 9+ */
|
|
||||||
text-decoration: underline dotted; /* Firefox 40+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
audio:not([controls]) {
|
|
||||||
display: none; /* Chrome 44-, iOS 8+, Safari 9+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
b,
|
|
||||||
strong {
|
|
||||||
font-weight: bolder; /* Edge 12+, Safari 6.2+, and Chrome 18+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
button {
|
|
||||||
-webkit-appearance: button; /* iOS 8+ */
|
|
||||||
overflow: visible; /* Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
input {
|
|
||||||
}
|
|
||||||
|
|
||||||
button::-moz-focus-inner, input::-moz-focus-inner {
|
|
||||||
border: 0;/* Firefox 4+ */
|
|
||||||
padding: 0;/* Firefox 4+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
button:-moz-focusring, input:-moz-focusring {
|
|
||||||
outline: 1px dotted ButtonText;/* Firefox 4+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
select {
|
|
||||||
text-transform: none; /* Firefox 40+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
details {
|
|
||||||
display: block; /* Edge 12+, Firefox 40+, Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
html {
|
|
||||||
-ms-overflow-style: -ms-autohiding-scrollbar; /* Edge 12+, Internet Explorer 11- */
|
|
||||||
overflow-y: scroll; /* All browsers without overlaying scrollbars */
|
|
||||||
-webkit-text-size-adjust: 100%; /* iOS 8+, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
hr {
|
|
||||||
overflow: visible; /* Internet Explorer 11-, Edge 12+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input {
|
|
||||||
-webkit-border-radius: 0 /* iOS 8+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="button"],
|
|
||||||
input[type="reset"],
|
|
||||||
input[type="submit"] {
|
|
||||||
-webkit-appearance: button;/* iOS 8+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="number"] {
|
|
||||||
width: auto;/* Firefox 36+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="search"] {
|
|
||||||
-webkit-appearance: textfield;/* Chrome 45+, Safari 9+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="search"]::-webkit-search-cancel-button,
|
|
||||||
input[type="search"]::-webkit-search-decoration {
|
|
||||||
-webkit-appearance: none;/* Chrome 45+, Safari 9+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
main {
|
|
||||||
display: block; /* Android 4.3-, Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
pre {
|
|
||||||
overflow: auto; /* Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
progress {
|
|
||||||
display: inline-block; /* Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
summary {
|
|
||||||
display: block; /* Firefox 40+, Internet Explorer 11-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
svg:not(:root) {
|
|
||||||
overflow: hidden; /* Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
template {
|
|
||||||
display: none; /* Android 4.3-, Internet Explorer 11-, iOS 7-, Safari 7-, Windows Phone 8.1+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
textarea {
|
|
||||||
overflow: auto; /* Edge 12+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
[hidden] {
|
|
||||||
display: none; /* Internet Explorer 10- */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Universal inheritance
|
|
||||||
*/
|
|
||||||
|
|
||||||
*,
|
|
||||||
:before,
|
|
||||||
:after {
|
|
||||||
box-sizing: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
* {
|
|
||||||
font-size: inherit;
|
|
||||||
line-height: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
:before,
|
|
||||||
:after {
|
|
||||||
text-decoration: inherit;
|
|
||||||
vertical-align: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
input,
|
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
font-family: inherit;
|
|
||||||
font-style: inherit;
|
|
||||||
font-weight: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Opinionated defaults
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* specify the margin and padding of all elements */
|
|
||||||
|
|
||||||
* {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the border style and width of all elements */
|
|
||||||
|
|
||||||
*,
|
|
||||||
:before,
|
|
||||||
:after {
|
|
||||||
border-style: solid;
|
|
||||||
border-width: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* remove the tapping delay from clickable elements */
|
|
||||||
|
|
||||||
a,
|
|
||||||
area,
|
|
||||||
button,
|
|
||||||
input,
|
|
||||||
label,
|
|
||||||
select,
|
|
||||||
textarea,
|
|
||||||
[tabindex] {
|
|
||||||
-ms-touch-action: manipulation;
|
|
||||||
touch-action: manipulation;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the standard appearance of selects */
|
|
||||||
|
|
||||||
select {
|
|
||||||
-moz-appearance: none; /* Firefox 40+ */
|
|
||||||
-webkit-appearance: none /* Chrome 45+ */
|
|
||||||
}
|
|
||||||
|
|
||||||
select::-ms-expand {
|
|
||||||
display: none;/* Edge 12+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
select::-ms-value {
|
|
||||||
color: currentColor;/* Edge 12+, Internet Explorer 11- */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* use current current as the default fill of svg elements */
|
|
||||||
|
|
||||||
svg {
|
|
||||||
fill: currentColor;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the progress cursor of updating elements */
|
|
||||||
|
|
||||||
[aria-busy="true"] {
|
|
||||||
cursor: progress;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the pointer cursor of trigger elements */
|
|
||||||
|
|
||||||
[aria-controls] {
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
|
|
||||||
|
|
||||||
[aria-disabled] {
|
|
||||||
cursor: default;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the style of visually hidden yet accessible elements */
|
|
||||||
|
|
||||||
[hidden][aria-hidden="false"] {
|
|
||||||
clip: rect(0 0 0 0);
|
|
||||||
display: inherit;
|
|
||||||
position: absolute
|
|
||||||
}
|
|
||||||
|
|
||||||
[hidden][aria-hidden="false"]:focus {
|
|
||||||
clip: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Configurable defaults
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* specify the background repeat of all elements */
|
|
||||||
|
|
||||||
* {
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the root styles of the document */
|
|
||||||
|
|
||||||
:root {
|
|
||||||
background-color: #ffffff;
|
|
||||||
box-sizing: border-box;
|
|
||||||
color: #000000;
|
|
||||||
cursor: default;
|
|
||||||
font: 100%/1.5 sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the text decoration of anchors */
|
|
||||||
|
|
||||||
a {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the alignment of media elements */
|
|
||||||
|
|
||||||
audio,
|
|
||||||
canvas,
|
|
||||||
iframe,
|
|
||||||
img,
|
|
||||||
svg,
|
|
||||||
video {
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the coloring of form elements */
|
|
||||||
|
|
||||||
button,
|
|
||||||
input,
|
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
background-color: transparent;
|
|
||||||
color: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the minimum height of form elements */
|
|
||||||
|
|
||||||
button,
|
|
||||||
[type="button"],
|
|
||||||
[type="date"],
|
|
||||||
[type="datetime"],
|
|
||||||
[type="datetime-local"],
|
|
||||||
[type="email"],
|
|
||||||
[type="month"],
|
|
||||||
[type="number"],
|
|
||||||
[type="password"],
|
|
||||||
[type="reset"],
|
|
||||||
[type="search"],
|
|
||||||
[type="submit"],
|
|
||||||
[type="tel"],
|
|
||||||
[type="text"],
|
|
||||||
[type="time"],
|
|
||||||
[type="url"],
|
|
||||||
[type="week"],
|
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
min-height: 1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the font family of code elements */
|
|
||||||
|
|
||||||
code,
|
|
||||||
kbd,
|
|
||||||
pre,
|
|
||||||
samp {
|
|
||||||
font-family: monospace, monospace;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the list style of nav lists */
|
|
||||||
|
|
||||||
nav ol,
|
|
||||||
nav ul {
|
|
||||||
list-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the font size of small elements */
|
|
||||||
|
|
||||||
small {
|
|
||||||
font-size: 75%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the border styling of tables */
|
|
||||||
|
|
||||||
table {
|
|
||||||
border-collapse: collapse;
|
|
||||||
border-spacing: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the resizability of textareas */
|
|
||||||
|
|
||||||
textarea {
|
|
||||||
resize: vertical;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* specify the background color, font color, and drop shadow of text selections */
|
|
||||||
|
|
||||||
::-moz-selection {
|
|
||||||
background-color: #b3d4fc; /* required when declaring ::selection */
|
|
||||||
color: #ffffff;
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
::selection {
|
|
||||||
background-color: #b3d4fc; /* required when declaring ::selection */
|
|
||||||
color: #ffffff;
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
Binary file not shown.
Binary file not shown.
|
@ -1,5 +0,0 @@
|
||||||
/*! store2 - v2.3.2 - 2015-10-27
|
|
||||||
* Copyright (c) 2015 Nathan Bubna; Licensed MIT, GPL */
|
|
||||||
|
|
||||||
!function(a,b){var c={version:"2.3.2",areas:{},apis:{},inherit:function(a,b){for(var c in a)b.hasOwnProperty(c)||(b[c]=a[c]);return b},stringify:function(a){return void 0===a||"function"==typeof a?a+"":JSON.stringify(a)},parse:function(a){try{return JSON.parse(a)}catch(b){return a}},fn:function(a,b){c.storeAPI[a]=b;for(var d in c.apis)c.apis[d][a]=b},get:function(a,b){return a.getItem(b)},set:function(a,b,c){a.setItem(b,c)},remove:function(a,b){a.removeItem(b)},key:function(a,b){return a.key(b)},length:function(a){return a.length},clear:function(a){a.clear()},Store:function(a,b,d){var e=c.inherit(c.storeAPI,function(a,b,c){return 0===arguments.length?e.getAll():void 0!==b?e.set(a,b,c):"string"==typeof a||"number"==typeof a?e.get(a):a?e.setAll(a,b):e.clear()});e._id=a;try{var f="_safariPrivate_";b.setItem(f,"sucks"),e._area=b,b.removeItem(f)}catch(g){}return e._area||(e._area=c.inherit(c.storageAPI,{items:{},name:"fake"})),e._ns=d||"",c.areas[a]||(c.areas[a]=e._area),c.apis[e._ns+e._id]||(c.apis[e._ns+e._id]=e),e},storeAPI:{area:function(a,b){var d=this[a];return d&&d.area||(d=c.Store(a,b,this._ns),this[a]||(this[a]=d)),d},namespace:function(a,b){if(!a)return this._ns?this._ns.substring(0,this._ns.length-1):"";var d=a,e=this[d];return e&&e.namespace||(e=c.Store(this._id,this._area,this._ns+d+"."),this[d]||(this[d]=e),b||e.area("session",c.areas.session)),e},isFake:function(){return"fake"===this._area.name},toString:function(){return"store"+(this._ns?"."+this.namespace():"")+"["+this._id+"]"},has:function(a){return this._area.has?this._area.has(this._in(a)):!!(this._in(a)in this._area)},size:function(){return this.keys().length},each:function(a,b){for(var d=0,e=c.length(this._area);e>d;d++){var f=this._out(c.key(this._area,d));if(void 0!==f&&a.call(this,f,b||this.get(f))===!1)break;e>c.length(this._area)&&(e--,d--)}return b||this},keys:function(){return this.each(function(a,b){b.push(a)},[])},get:function(a,b){var d=c.get(this._area,this._in(a));return null!==d?c.parse(d):b||d},getAll:function(){return this.each(function(a,b){b[a]=this.get(a)},{})},set:function(a,b,d){var e=this.get(a);return null!=e&&d===!1?b:c.set(this._area,this._in(a),c.stringify(b),d)||e},setAll:function(a,b){var c,d;for(var e in a)d=a[e],this.set(e,d,b)!==d&&(c=!0);return c},remove:function(a){var b=this.get(a);return c.remove(this._area,this._in(a)),b},clear:function(){return this._ns?this.each(function(a){c.remove(this._area,this._in(a))},1):c.clear(this._area),this},clearAll:function(){var a=this._area;for(var b in c.areas)c.areas.hasOwnProperty(b)&&(this._area=c.areas[b],this.clear());return this._area=a,this},_in:function(a){return"string"!=typeof a&&(a=c.stringify(a)),this._ns?this._ns+a:a},_out:function(a){return this._ns?a&&0===a.indexOf(this._ns)?a.substring(this._ns.length):void 0:a}},storageAPI:{length:0,has:function(a){return this.items.hasOwnProperty(a)},key:function(a){var b=0;for(var c in this.items)if(this.has(c)&&a===b++)return c},setItem:function(a,b){this.has(a)||this.length++,this.items[a]=b},removeItem:function(a){this.has(a)&&(delete this.items[a],this.length--)},getItem:function(a){return this.has(a)?this.items[a]:null},clear:function(){for(var a in this.list)this.removeItem(a)},toString:function(){return this.length+" items in "+this.name+"Storage"}}};a.store&&(c.conflict=a.store);var d=c.Store("local",function(){try{return localStorage}catch(a){}}());d.local=d,d._=c,d.area("session",function(){try{return sessionStorage}catch(a){}}()),a.store=d,"function"==typeof b&&void 0!==b.amd?b(function(){return d}):"undefined"!=typeof module&&module.exports&&(module.exports=d)}(this,this.define);
|
|
||||||
//# sourceMappingURL=store2.min.js.map
|
|
246
public/build/assets/css/global-5eaecdf53d.css
vendored
246
public/build/assets/css/global-5eaecdf53d.css
vendored
|
@ -1,246 +0,0 @@
|
||||||
html {
|
|
||||||
background: url("/assets/img/escheresque.png"); }
|
|
||||||
|
|
||||||
.map {
|
|
||||||
height: 150px; }
|
|
||||||
|
|
||||||
html {
|
|
||||||
box-sizing: border-box; }
|
|
||||||
|
|
||||||
*,
|
|
||||||
*::before,
|
|
||||||
*::after {
|
|
||||||
box-sizing: inherit; }
|
|
||||||
|
|
||||||
#topheader {
|
|
||||||
display: -webkit-box;
|
|
||||||
display: flex;
|
|
||||||
flex-flow: row; }
|
|
||||||
|
|
||||||
#topheader a {
|
|
||||||
padding: 0.5em 1em; }
|
|
||||||
|
|
||||||
nav {
|
|
||||||
padding-top: 0.5em; }
|
|
||||||
|
|
||||||
.social-list {
|
|
||||||
padding-left: 2em; }
|
|
||||||
|
|
||||||
.note {
|
|
||||||
background-color: #eee8d5;
|
|
||||||
box-shadow: 0 0 10px 2px #93a1a1;
|
|
||||||
padding: 0.5em;
|
|
||||||
margin-top: 1em; }
|
|
||||||
|
|
||||||
.note::after {
|
|
||||||
content: " ";
|
|
||||||
display: block;
|
|
||||||
height: 0;
|
|
||||||
clear: both; }
|
|
||||||
|
|
||||||
.note a {
|
|
||||||
word-wrap: break-word; }
|
|
||||||
|
|
||||||
.note .e-content p:first-child {
|
|
||||||
margin-top: 0; }
|
|
||||||
|
|
||||||
.note-metadata {
|
|
||||||
width: 100%; }
|
|
||||||
|
|
||||||
.social-links {
|
|
||||||
float: right; }
|
|
||||||
|
|
||||||
.social-links a {
|
|
||||||
text-decoration: none; }
|
|
||||||
|
|
||||||
.icon {
|
|
||||||
width: auto;
|
|
||||||
height: 1em;
|
|
||||||
fill: #268bd2; }
|
|
||||||
|
|
||||||
.reply {
|
|
||||||
margin-left: 2em;
|
|
||||||
margin-right: 2em;
|
|
||||||
font-size: 0.8em;
|
|
||||||
padding: 0.5em; }
|
|
||||||
|
|
||||||
.reply-to {
|
|
||||||
margin-left: 2em;
|
|
||||||
margin-right: 2em;
|
|
||||||
font-size: 0.8em;
|
|
||||||
padding-top: 2em; }
|
|
||||||
|
|
||||||
.reply-to + .note {
|
|
||||||
margin-top: 0.3em; }
|
|
||||||
|
|
||||||
.mini-h-card {
|
|
||||||
border-radius: 2px;
|
|
||||||
border: 1px solid #586e75;
|
|
||||||
padding: 0 0.2em;
|
|
||||||
text-decoration: none;
|
|
||||||
margin-right: 5px;
|
|
||||||
white-space: nowrap; }
|
|
||||||
|
|
||||||
.mini-h-card img {
|
|
||||||
height: 1em;
|
|
||||||
border-radius: 2px;
|
|
||||||
vertical-align: text-bottom; }
|
|
||||||
|
|
||||||
.like-photo {
|
|
||||||
height: 1.26em; }
|
|
||||||
|
|
||||||
.reply .e-content {
|
|
||||||
margin-top: 0.5em;
|
|
||||||
padding-left: 0.5em; }
|
|
||||||
|
|
||||||
.notes-subtitle {
|
|
||||||
font-size: 1em; }
|
|
||||||
|
|
||||||
.note-photo {
|
|
||||||
width: 100%;
|
|
||||||
height: auto;
|
|
||||||
image-orientation: from-image; }
|
|
||||||
|
|
||||||
article header {
|
|
||||||
margin-top: 0.5em;
|
|
||||||
margin-bottom: 0.8em; }
|
|
||||||
|
|
||||||
.post-info {
|
|
||||||
font-size: 0.8em;
|
|
||||||
font-style: italic;
|
|
||||||
margin-top: -0.8em; }
|
|
||||||
|
|
||||||
.contact {
|
|
||||||
position: relative; }
|
|
||||||
|
|
||||||
.contact-links {
|
|
||||||
list-style-type: none; }
|
|
||||||
|
|
||||||
.contact img {
|
|
||||||
height: auto;
|
|
||||||
width: 2em;
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0; }
|
|
||||||
|
|
||||||
.contact-info {
|
|
||||||
margin-left: 2em; }
|
|
||||||
|
|
||||||
#map {
|
|
||||||
height: 300px; }
|
|
||||||
|
|
||||||
/* media queries */
|
|
||||||
@media (min-width: 700px) {
|
|
||||||
main {
|
|
||||||
margin-left: 10em;
|
|
||||||
margin-right: 10em; }
|
|
||||||
footer {
|
|
||||||
margin-left: 13em;
|
|
||||||
margin-right: 13em; }
|
|
||||||
.youtube {
|
|
||||||
width: 640px;
|
|
||||||
height: 360px; } }
|
|
||||||
|
|
||||||
@media (max-width: 699px) {
|
|
||||||
main {
|
|
||||||
margin-left: 10px;
|
|
||||||
margin-right: 10px; }
|
|
||||||
article {
|
|
||||||
word-wrap: break-word; }
|
|
||||||
footer {
|
|
||||||
margin-left: 15px;
|
|
||||||
margin-right: 15px; }
|
|
||||||
.youtube {
|
|
||||||
width: 100%;
|
|
||||||
height: auto; } }
|
|
||||||
|
|
||||||
body {
|
|
||||||
text-rendering: optimizeLegibility;
|
|
||||||
-webkit-font-feature-settings: "liga";
|
|
||||||
font-feature-settings: "liga";
|
|
||||||
font-family: "leitura-news", serif;
|
|
||||||
font-size: 1.2em; }
|
|
||||||
|
|
||||||
#topheader h1 {
|
|
||||||
font-family: "leitura-news", serif; }
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
font-family: "prenton", sans-serif; }
|
|
||||||
|
|
||||||
#topheader a {
|
|
||||||
text-decoration: none; }
|
|
||||||
|
|
||||||
nav {
|
|
||||||
-webkit-font-feature-settings: "dlig";
|
|
||||||
font-feature-settings: "dlig"; }
|
|
||||||
|
|
||||||
article header h1 a {
|
|
||||||
text-decoration: none; }
|
|
||||||
|
|
||||||
article div a {
|
|
||||||
text-decoration: none; }
|
|
||||||
|
|
||||||
footer {
|
|
||||||
font-size: 0.8em; }
|
|
||||||
|
|
||||||
.emoji {
|
|
||||||
width: auto;
|
|
||||||
height: 1em; }
|
|
||||||
|
|
||||||
body {
|
|
||||||
color: #002b36; }
|
|
||||||
|
|
||||||
header a {
|
|
||||||
color: #002b36; }
|
|
||||||
|
|
||||||
a {
|
|
||||||
color: #268bd2; }
|
|
||||||
|
|
||||||
form {
|
|
||||||
width: 100%; }
|
|
||||||
|
|
||||||
fieldset {
|
|
||||||
min-width: 0;
|
|
||||||
width: 100%; }
|
|
||||||
|
|
||||||
input[type="text"],
|
|
||||||
input[type="file"],
|
|
||||||
textarea {
|
|
||||||
width: 100%; }
|
|
||||||
|
|
||||||
input,
|
|
||||||
button,
|
|
||||||
textarea {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
-moz-appearance: none;
|
|
||||||
background-color: #002b36;
|
|
||||||
color: #fdf6e3;
|
|
||||||
border: 1px solid #fdf6e3;
|
|
||||||
border-radius: 4px; }
|
|
||||||
|
|
||||||
button:hover {
|
|
||||||
-webkit-transition: 0.5s ease-in-out;
|
|
||||||
transition: 0.5s ease-in-out;
|
|
||||||
background-color: #fdf6e3;
|
|
||||||
color: #002b36; }
|
|
||||||
|
|
||||||
button:disabled {
|
|
||||||
background-color: #93a1a1;
|
|
||||||
color: #002b36; }
|
|
||||||
|
|
||||||
input[type="checkbox"] {
|
|
||||||
-webkit-appearance: checkbox;
|
|
||||||
-moz-appearance: checkbox; }
|
|
||||||
|
|
||||||
#photo {
|
|
||||||
background: inherit;
|
|
||||||
color: inherit;
|
|
||||||
border: none; }
|
|
||||||
|
|
||||||
.twitter-tweet-rendered {
|
|
||||||
margin-bottom: 0 !important; }
|
|
||||||
|
|
||||||
.twitter-tweet-rendered + .note {
|
|
||||||
margin-top: 0; }
|
|
||||||
|
|
||||||
/*# sourceMappingURL=global.css.map */
|
|
Binary file not shown.
Binary file not shown.
File diff suppressed because one or more lines are too long
10
public/build/assets/css/projects-d945298e4f.css
vendored
10
public/build/assets/css/projects-d945298e4f.css
vendored
|
@ -1,10 +0,0 @@
|
||||||
#projects {
|
|
||||||
padding-left: 33.33%;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
float: left;
|
|
||||||
width: 45%;
|
|
||||||
margin: 0 5% 0 -50%;
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
|
@ -1,69 +0,0 @@
|
||||||
/* global alertify, store */
|
|
||||||
var feature = {
|
|
||||||
addEventListener : !!window.addEventListener,
|
|
||||||
querySelectorAll : !!document.querySelectorAll
|
|
||||||
};
|
|
||||||
|
|
||||||
if (feature.addEventListener && feature.querySelectorAll) {
|
|
||||||
var keys = getKeys();
|
|
||||||
for (var i = 0; i < keys.length; i++) {
|
|
||||||
if (store.get(keys[i])) {
|
|
||||||
var formId = keys[i].split('~')[1];
|
|
||||||
document.getElementById(formId).value = store.get(keys[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var timerId = window.setInterval(function() {
|
|
||||||
var saved = false;
|
|
||||||
var inputs = document.querySelectorAll('input[type=text], textarea');
|
|
||||||
for (var i = 0; i < inputs.length; i++) {
|
|
||||||
var key = getFormElement(inputs[i]).id + '~' + inputs[i].id;
|
|
||||||
if (store.get(key) !== inputs[i].value && inputs[i].value !== '') {
|
|
||||||
store.set(key, inputs[i].value);
|
|
||||||
saved = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (saved === true) {
|
|
||||||
alertify.logPosition('top right');
|
|
||||||
alertify.success('Auto saved text');
|
|
||||||
}
|
|
||||||
}, 5000);
|
|
||||||
var forms = document.querySelectorAll('form');
|
|
||||||
for (var f = 0; f < forms.length; f++) {
|
|
||||||
var form = forms[f];
|
|
||||||
form.addEventListener('submit', function() {
|
|
||||||
window.clearInterval(timerId);
|
|
||||||
var formId = form.id;
|
|
||||||
var storedKeys = store.keys();
|
|
||||||
for (var i = 0; i < storedKeys.length; i++) {
|
|
||||||
if (storedKeys[i].indexOf(formId) > -1) {
|
|
||||||
store.remove(storedKeys[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
function getKeys() {
|
|
||||||
var keys = [];
|
|
||||||
var formFields = document.querySelectorAll('input[type=text], textarea');
|
|
||||||
for (var f = 0; f < formFields.length; f++) {
|
|
||||||
var parent = getFormElement(formFields[f]);
|
|
||||||
if (parent !== false) {
|
|
||||||
var key = parent.id + '~' + formFields[f].id;
|
|
||||||
keys.push(key);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return keys;
|
|
||||||
}
|
|
||||||
function getFormElement(elem) {
|
|
||||||
if (elem.nodeName.toLowerCase() !== 'body') {
|
|
||||||
var parent = elem.parentNode;
|
|
||||||
if (parent.nodeName.toLowerCase() === 'form') {
|
|
||||||
return parent;
|
|
||||||
} else {
|
|
||||||
return getFormElement(parent);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,26 +0,0 @@
|
||||||
/* global Autolinker */
|
|
||||||
//the autlinker object
|
|
||||||
var autolinker = new Autolinker();
|
|
||||||
|
|
||||||
//the youtube regex
|
|
||||||
var ytidregex = /watch\?v=([A-Za-z0-9\-_]+)/;
|
|
||||||
|
|
||||||
//grab the notes and loop through them
|
|
||||||
var notes = document.querySelectorAll('.e-content');
|
|
||||||
for (var i = 0; i < notes.length; i++) {
|
|
||||||
//get Youtube ID
|
|
||||||
var ytid = notes[i].textContent.match(ytidregex);
|
|
||||||
if (ytid !== null) {
|
|
||||||
var id = ytid[1];
|
|
||||||
var iframe = document.createElement('iframe');
|
|
||||||
iframe.classList.add('youtube');
|
|
||||||
iframe.setAttribute('src', '//www.youtube.com/embed/' + id);
|
|
||||||
iframe.setAttribute('frameborder', 0);
|
|
||||||
iframe.setAttribute('allowfullscreen', 'true');
|
|
||||||
notes[i].appendChild(iframe);
|
|
||||||
}
|
|
||||||
//now linkify everything
|
|
||||||
var orig = notes[i].innerHTML;
|
|
||||||
var linked = autolinker.link(orig);
|
|
||||||
notes[i].innerHTML = linked;
|
|
||||||
}
|
|
|
@ -1,16 +0,0 @@
|
||||||
/* global L */
|
|
||||||
//This code runs on page load and looks for <div class="map">, then adds map
|
|
||||||
var mapDivs = document.querySelectorAll('.map');
|
|
||||||
for (var i = 0; i < mapDivs.length; i++) {
|
|
||||||
var mapDiv = mapDivs[i];
|
|
||||||
var latitude = mapDiv.dataset.latitude;
|
|
||||||
var longitude = mapDiv.dataset.longitude;
|
|
||||||
L.mapbox.accessToken = 'pk.eyJ1Ijoiam9ubnliYXJuZXMiLCJhIjoiVlpndW1EYyJ9.aP9fxAqLKh7lj0LpFh5k1w';
|
|
||||||
var map = L.mapbox.map(mapDiv, 'jonnybarnes.gnoihnim')
|
|
||||||
.setView([latitude, longitude], 15)
|
|
||||||
.addLayer(L.mapbox.tileLayer('jonnybarnes.gnoihnim', {
|
|
||||||
detectRetina: true
|
|
||||||
}));
|
|
||||||
L.marker([latitude, longitude]).addTo(map);
|
|
||||||
map.scrollWheelZoom.disable();
|
|
||||||
}
|
|
|
@ -1,281 +0,0 @@
|
||||||
/* global L */
|
|
||||||
if ('geolocation' in navigator) {
|
|
||||||
var button = document.querySelector('#locate');
|
|
||||||
if (button.addEventListener) {
|
|
||||||
//if we have javascript, event listeners and geolocation, make the locate
|
|
||||||
//button clickable and add event
|
|
||||||
button.disabled = false;
|
|
||||||
button.addEventListener('click', getLocation);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function getLocation() {
|
|
||||||
navigator.geolocation.getCurrentPosition(function (position) {
|
|
||||||
//the locate button has been clicked so add the places/map
|
|
||||||
addPlaces(position.coords.latitude, position.coords.longitude);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function addPlaces(latitude, longitude) {
|
|
||||||
//get the nearby places
|
|
||||||
fetch('/places/near/' + latitude + '/' + longitude, {
|
|
||||||
credentials: 'same-origin',
|
|
||||||
method: 'get'
|
|
||||||
}).then(function (response) {
|
|
||||||
return response.json();
|
|
||||||
}).then(function (j) {
|
|
||||||
if (j.length > 0) {
|
|
||||||
var i;
|
|
||||||
var places = [];
|
|
||||||
for (i = 0; i < j.length; ++i) {
|
|
||||||
var latlng = parseLocation(j[i].location);
|
|
||||||
var name = j[i].name;
|
|
||||||
var slug = j[i].slug;
|
|
||||||
places.push([name, slug, latlng[0], latlng[1]]);
|
|
||||||
}
|
|
||||||
//add a map with the nearby places
|
|
||||||
addMap(latitude, longitude, places);
|
|
||||||
} else {
|
|
||||||
//add a map with just current location
|
|
||||||
addMap(latitude, longitude);
|
|
||||||
}
|
|
||||||
}).catch(function (err) {
|
|
||||||
console.error(err);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function addMap(latitude, longitude, places) {
|
|
||||||
//make places null if not supplied
|
|
||||||
if (arguments.length == 2) {
|
|
||||||
places = null;
|
|
||||||
}
|
|
||||||
var form = button.parentNode;
|
|
||||||
var div = document.createElement('div');
|
|
||||||
div.setAttribute('id', 'map');
|
|
||||||
//add the map div
|
|
||||||
form.appendChild(div);
|
|
||||||
L.mapbox.accessToken = 'pk.eyJ1Ijoiam9ubnliYXJuZXMiLCJhIjoiVlpndW1EYyJ9.aP9fxAqLKh7lj0LpFh5k1w';
|
|
||||||
var map = L.mapbox.map('map', 'jonnybarnes.gnoihnim')
|
|
||||||
.setView([latitude, longitude], 15)
|
|
||||||
.addLayer(L.mapbox.tileLayer('jonnybarnes.gnoihnim', {
|
|
||||||
detectRetina: true
|
|
||||||
}));
|
|
||||||
//add a marker for the current location
|
|
||||||
var marker = L.marker([latitude, longitude], {
|
|
||||||
draggable: true
|
|
||||||
}).addTo(map);
|
|
||||||
//when the location marker is dragged, if the new place form elements exist
|
|
||||||
//update the lat/lng values
|
|
||||||
marker.on('dragend', function () {
|
|
||||||
var placeFormLatitude = document.querySelector('#place-latitude');
|
|
||||||
if (placeFormLatitude !== null) {
|
|
||||||
placeFormLatitude.value = getLatitudeFromMapboxMarker(marker.getLatLng());
|
|
||||||
}
|
|
||||||
var placeFormLongitude = document.querySelector('#place-longitude');
|
|
||||||
if (placeFormLongitude !== null) {
|
|
||||||
placeFormLongitude.value = getLongitudeFromMapboxMarker(marker.getLatLng());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
//create the <select> element and give it a no location default
|
|
||||||
var selectEl = document.createElement('select');
|
|
||||||
selectEl.setAttribute('name', 'location');
|
|
||||||
var noLocation = document.createElement('option');
|
|
||||||
noLocation.setAttribute('selected', 'selected');
|
|
||||||
noLocation.setAttribute('value', 'no-location');
|
|
||||||
var noLocText = document.createTextNode('Select no location');
|
|
||||||
noLocation.appendChild(noLocText);
|
|
||||||
selectEl.appendChild(noLocation);
|
|
||||||
form.insertBefore(selectEl, div);
|
|
||||||
if (places !== null) {
|
|
||||||
//add the places both to the map and <select>
|
|
||||||
places.forEach(function (item) {
|
|
||||||
var option = document.createElement('option');
|
|
||||||
option.setAttribute('value', item[1]);
|
|
||||||
var text = document.createTextNode(item[0]);
|
|
||||||
option.appendChild(text);
|
|
||||||
option.dataset.latitude = item[2];
|
|
||||||
option.dataset.longitude = item[3];
|
|
||||||
selectEl.appendChild(option);
|
|
||||||
var placeMarker = L.marker([item[2], item[3]], {
|
|
||||||
icon: L.mapbox.marker.icon({
|
|
||||||
'marker-size': 'large',
|
|
||||||
'marker-symbol': 'building',
|
|
||||||
'marker-color': '#fa0'
|
|
||||||
})
|
|
||||||
}).addTo(map);
|
|
||||||
var name = 'Name: ' + item[0];
|
|
||||||
placeMarker.bindPopup(name, {
|
|
||||||
closeButton: true
|
|
||||||
});
|
|
||||||
placeMarker.on('click', function () {
|
|
||||||
map.panTo([item[2], item[3]]);
|
|
||||||
selectPlace(item[1]);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
//add an event listener
|
|
||||||
selectEl.addEventListener('change', function () {
|
|
||||||
if (selectEl.value !== 'no-location') {
|
|
||||||
var placeLat = selectEl[selectEl.selectedIndex].dataset.latitude;
|
|
||||||
var placeLon = selectEl[selectEl.selectedIndex].dataset.longitude;
|
|
||||||
map.panTo([placeLat, placeLon]);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
//add a button to add a new place
|
|
||||||
var newLocButton = document.createElement('button');
|
|
||||||
newLocButton.setAttribute('type', 'button');
|
|
||||||
newLocButton.setAttribute('id', 'create-new-place');
|
|
||||||
newLocButton.appendChild(document.createTextNode('Create New Place?'));
|
|
||||||
//the event listener
|
|
||||||
newLocButton.addEventListener('click', function() {
|
|
||||||
//add the form elements
|
|
||||||
var nameLabel = document.createElement('label');
|
|
||||||
nameLabel.setAttribute('for', 'place-name');
|
|
||||||
nameLabel.classList.add('place-label');
|
|
||||||
nameLabel.appendChild(document.createTextNode('Place Name:'));
|
|
||||||
var nameEl = document.createElement('input');
|
|
||||||
nameEl.setAttribute('placeholder', 'Name');
|
|
||||||
nameEl.setAttribute('name', 'place-name');
|
|
||||||
nameEl.setAttribute('id', 'place-name');
|
|
||||||
nameEl.setAttribute('type', 'text');
|
|
||||||
var descLabel = document.createElement('label');
|
|
||||||
descLabel.setAttribute('for', 'place-description');
|
|
||||||
descLabel.classList.add('place-label');
|
|
||||||
descLabel.appendChild(document.createTextNode('Place Description:'));
|
|
||||||
var descEl = document.createElement('input');
|
|
||||||
descEl.setAttribute('placeholder', 'Description');
|
|
||||||
descEl.setAttribute('name', 'place-description');
|
|
||||||
descEl.setAttribute('id', 'place-description');
|
|
||||||
descEl.setAttribute('type', 'text');
|
|
||||||
var latLabel = document.createElement('label');
|
|
||||||
latLabel.setAttribute('for', 'place-latitude');
|
|
||||||
latLabel.classList.add('place-label');
|
|
||||||
latLabel.appendChild(document.createTextNode('Place Latitude:'));
|
|
||||||
var latEl = document.createElement('input');
|
|
||||||
latEl.setAttribute('name', 'place-latitude');
|
|
||||||
latEl.setAttribute('id', 'place-latitude');
|
|
||||||
latEl.setAttribute('type', 'text');
|
|
||||||
latEl.value = getLatitudeFromMapboxMarker(marker.getLatLng());
|
|
||||||
var lonLabel = document.createElement('label');
|
|
||||||
lonLabel.setAttribute('for', 'place-longitude');
|
|
||||||
lonLabel.classList.add('place-label');
|
|
||||||
lonLabel.appendChild(document.createTextNode('Place Longitude:'));
|
|
||||||
var lonEl = document.createElement('input');
|
|
||||||
lonEl.setAttribute('name', 'place-longitude');
|
|
||||||
lonEl.setAttribute('id', 'place-longitude');
|
|
||||||
lonEl.setAttribute('type', 'text');
|
|
||||||
lonEl.value = getLongitudeFromMapboxMarker(marker.getLatLng());
|
|
||||||
var placeSubmit = document.createElement('button');
|
|
||||||
placeSubmit.setAttribute('id', 'place-submit');
|
|
||||||
placeSubmit.setAttribute('value', 'Submit New Place');
|
|
||||||
placeSubmit.setAttribute('name', 'place-submit');
|
|
||||||
placeSubmit.setAttribute('type', 'button');
|
|
||||||
placeSubmit.appendChild(document.createTextNode('Submit New Place'));
|
|
||||||
form.appendChild(nameLabel);
|
|
||||||
form.appendChild(nameEl);
|
|
||||||
form.appendChild(descLabel);
|
|
||||||
form.appendChild(descEl);
|
|
||||||
form.appendChild(latLabel);
|
|
||||||
form.appendChild(latEl);
|
|
||||||
form.appendChild(lonLabel);
|
|
||||||
form.appendChild(lonEl);
|
|
||||||
form.appendChild(placeSubmit);
|
|
||||||
//the event listener for the new place form
|
|
||||||
placeSubmit.addEventListener('click', function () {
|
|
||||||
//create the form data to send
|
|
||||||
var formData = new FormData();
|
|
||||||
formData.append('place-name', document.querySelector('#place-name').value);
|
|
||||||
formData.append('place-description', document.querySelector('#place-description').value);
|
|
||||||
formData.append('place-latitude', document.querySelector('#place-latitude').value);
|
|
||||||
formData.append('place-longitude', document.querySelector('#place-longitude').value);
|
|
||||||
//post the new place
|
|
||||||
fetch('/places/new', {
|
|
||||||
//send cookies with the request
|
|
||||||
credentials: 'same-origin',
|
|
||||||
method: 'post',
|
|
||||||
body: formData
|
|
||||||
})
|
|
||||||
.then(function (response) {
|
|
||||||
if (response.status >= 200 && response.status < 300) {
|
|
||||||
return Promise.resolve(response);
|
|
||||||
} else {
|
|
||||||
return Promise.reject(new Error(response.statusText));
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.then(function (response) {
|
|
||||||
return response.json();
|
|
||||||
})
|
|
||||||
.then(function (placeJson) {
|
|
||||||
//create the slug from the url
|
|
||||||
var urlParts = placeJson.split('/');
|
|
||||||
var slug = urlParts.pop();
|
|
||||||
//remove un-needed form elements
|
|
||||||
form.removeChild(document.querySelector('#place-name'));
|
|
||||||
form.removeChild(document.querySelector('#place-description'));
|
|
||||||
form.removeChild(document.querySelector('#place-latitude'));
|
|
||||||
form.removeChild(document.querySelector('#place-longitude'));
|
|
||||||
var labels = document.querySelectorAll('.place-label');
|
|
||||||
for (var i = 0; i < labels.length; ++i) {
|
|
||||||
form.removeChild(labels[i]);
|
|
||||||
}
|
|
||||||
form.removeChild(document.querySelector('#place-submit'));
|
|
||||||
form.removeChild(document.querySelector('#create-new-place'));
|
|
||||||
//remove location marker
|
|
||||||
map.removeLayer(marker);
|
|
||||||
//add place marker
|
|
||||||
var newOption = document.createElement('option');
|
|
||||||
newOption.setAttribute('value', slug);
|
|
||||||
newOption.appendChild(document.createTextNode(placeJson['name']));
|
|
||||||
newOption.dataset.latitude = placeJson['latitude'];
|
|
||||||
newOption.dataset.longitude = placeJson['longitude'];
|
|
||||||
selectEl.appendChild(newOption);
|
|
||||||
var newPlaceMarker = L.marker([placeJson['latitude'], placeJson['longitude']], {
|
|
||||||
icon: L.mapbox.marker.icon({
|
|
||||||
'marker-size': 'large',
|
|
||||||
'marker-symbol': 'building',
|
|
||||||
'marker-color': '#fa0'
|
|
||||||
})
|
|
||||||
}).addTo(map);
|
|
||||||
var newName = 'Name: ' + placeJson['name'];
|
|
||||||
newPlaceMarker.bindPopup(newName, {
|
|
||||||
closeButton: true
|
|
||||||
});
|
|
||||||
newPlaceMarker.on('click', function () {
|
|
||||||
map.panTo([placeJson['latitude'], placeJson['longitude']]);
|
|
||||||
selectPlace(slug);
|
|
||||||
});
|
|
||||||
//make selected
|
|
||||||
selectPlace(slug);
|
|
||||||
}).catch(function (placeError) {
|
|
||||||
console.error(placeError);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
form.insertBefore(newLocButton, div);
|
|
||||||
}
|
|
||||||
|
|
||||||
function parseLocation(point) {
|
|
||||||
var re = /\((.*)\)/;
|
|
||||||
var resultArray = re.exec(point);
|
|
||||||
var location = resultArray[1].split(' ');
|
|
||||||
|
|
||||||
return [location[1], location[0]];
|
|
||||||
}
|
|
||||||
|
|
||||||
function selectPlace(slug) {
|
|
||||||
document.querySelector('select [value=' + slug + ']').selected = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function getLatitudeFromMapboxMarker(latlng) {
|
|
||||||
var resultArray = /\((.*)\)/.exec(latlng);
|
|
||||||
var location = resultArray[1].split(' ');
|
|
||||||
|
|
||||||
return location[0].replace(',', '');
|
|
||||||
}
|
|
||||||
|
|
||||||
function getLongitudeFromMapboxMarker(latlng) {
|
|
||||||
var resultArray = /\((.*)\)/.exec(latlng);
|
|
||||||
var location = resultArray[1].split(' ');
|
|
||||||
|
|
||||||
return location[1];
|
|
||||||
}
|
|
|
@ -1,44 +0,0 @@
|
||||||
/* global L */
|
|
||||||
var button = document.querySelector('#locate');
|
|
||||||
|
|
||||||
if (button.addEventListener) {
|
|
||||||
button.addEventListener('click', getLocation);
|
|
||||||
} else {
|
|
||||||
button.attachEvent('onclick', getLocation);
|
|
||||||
}
|
|
||||||
|
|
||||||
function getLocation() {
|
|
||||||
if ('geolocation' in navigator) {
|
|
||||||
navigator.geolocation.getCurrentPosition(function(position) {
|
|
||||||
updateForm(position.coords.latitude, position.coords.longitude);
|
|
||||||
addMap(position.coords.latitude, position.coords.longitude);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateForm(latitude, longitude) {
|
|
||||||
var inputLatitude = document.querySelector('#latitude');
|
|
||||||
var inputLongitude = document.querySelector('#longitude');
|
|
||||||
inputLatitude.value = latitude;
|
|
||||||
inputLongitude.value = longitude;
|
|
||||||
}
|
|
||||||
|
|
||||||
function addMap(latitude, longitude) {
|
|
||||||
var form = document.querySelector('form');
|
|
||||||
var div = document.createElement('div');
|
|
||||||
div.setAttribute('id', 'map');
|
|
||||||
form.appendChild(div);
|
|
||||||
L.mapbox.accessToken = 'pk.eyJ1Ijoiam9ubnliYXJuZXMiLCJhIjoiVlpndW1EYyJ9.aP9fxAqLKh7lj0LpFh5k1w';
|
|
||||||
var map = L.mapbox.map('map', 'jonnybarnes.gnoihnim')
|
|
||||||
.setView([latitude, longitude], 15)
|
|
||||||
.addLayer(L.mapbox.tileLayer('jonnybarnes.gnoihnim', {
|
|
||||||
detectRetina: true
|
|
||||||
}));
|
|
||||||
var marker = L.marker([latitude, longitude], {
|
|
||||||
draggable: true
|
|
||||||
}).addTo(map);
|
|
||||||
marker.on('dragend', function () {
|
|
||||||
var markerLocation = marker.getLatLng();
|
|
||||||
updateForm(markerLocation.lat, markerLocation.lng);
|
|
||||||
});
|
|
||||||
}
|
|
188
public/build/assets/prism/prism-5c98941a94.css
vendored
188
public/build/assets/prism/prism-5c98941a94.css
vendored
|
@ -1,188 +0,0 @@
|
||||||
/* http://prismjs.com/download.html?themes=prism-dark&languages=markup+css+clike+javascript+git+http+markdown+php+php-extras+scss+sql&plugins=line-numbers+show-invisibles */
|
|
||||||
/**
|
|
||||||
* prism.js Dark theme for JavaScript, CSS and HTML
|
|
||||||
* Based on the slides of the talk “/Reg(exp){2}lained/”
|
|
||||||
* @author Lea Verou
|
|
||||||
*/
|
|
||||||
|
|
||||||
code[class*="language-"],
|
|
||||||
pre[class*="language-"] {
|
|
||||||
color: white;
|
|
||||||
text-shadow: 0 -.1em .2em black;
|
|
||||||
font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
|
|
||||||
direction: ltr;
|
|
||||||
text-align: left;
|
|
||||||
white-space: pre;
|
|
||||||
word-spacing: normal;
|
|
||||||
word-break: normal;
|
|
||||||
line-height: 1.5;
|
|
||||||
|
|
||||||
-moz-tab-size: 4;
|
|
||||||
-o-tab-size: 4;
|
|
||||||
tab-size: 4;
|
|
||||||
|
|
||||||
-webkit-hyphens: none;
|
|
||||||
-moz-hyphens: none;
|
|
||||||
-ms-hyphens: none;
|
|
||||||
hyphens: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media print {
|
|
||||||
code[class*="language-"],
|
|
||||||
pre[class*="language-"] {
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pre[class*="language-"],
|
|
||||||
:not(pre) > code[class*="language-"] {
|
|
||||||
background: hsl(30, 20%, 25%);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Code blocks */
|
|
||||||
pre[class*="language-"] {
|
|
||||||
padding: 1em;
|
|
||||||
margin: .5em 0;
|
|
||||||
overflow: auto;
|
|
||||||
border: .3em solid hsl(30, 20%, 40%);
|
|
||||||
border-radius: .5em;
|
|
||||||
box-shadow: 1px 1px .5em black inset;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Inline code */
|
|
||||||
:not(pre) > code[class*="language-"] {
|
|
||||||
padding: .15em .2em .05em;
|
|
||||||
border-radius: .3em;
|
|
||||||
border: .13em solid hsl(30, 20%, 40%);
|
|
||||||
box-shadow: 1px 1px .3em -.1em black inset;
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.comment,
|
|
||||||
.token.prolog,
|
|
||||||
.token.doctype,
|
|
||||||
.token.cdata {
|
|
||||||
color: hsl(30, 20%, 50%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.punctuation {
|
|
||||||
opacity: .7;
|
|
||||||
}
|
|
||||||
|
|
||||||
.namespace {
|
|
||||||
opacity: .7;
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.property,
|
|
||||||
.token.tag,
|
|
||||||
.token.boolean,
|
|
||||||
.token.number,
|
|
||||||
.token.constant,
|
|
||||||
.token.symbol {
|
|
||||||
color: hsl(350, 40%, 70%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.selector,
|
|
||||||
.token.attr-name,
|
|
||||||
.token.string,
|
|
||||||
.token.char,
|
|
||||||
.token.builtin,
|
|
||||||
.token.inserted {
|
|
||||||
color: hsl(75, 70%, 60%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.operator,
|
|
||||||
.token.entity,
|
|
||||||
.token.url,
|
|
||||||
.language-css .token.string,
|
|
||||||
.style .token.string,
|
|
||||||
.token.variable {
|
|
||||||
color: hsl(40, 90%, 60%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.atrule,
|
|
||||||
.token.attr-value,
|
|
||||||
.token.keyword {
|
|
||||||
color: hsl(350, 40%, 70%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.regex,
|
|
||||||
.token.important {
|
|
||||||
color: #e90;
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.important,
|
|
||||||
.token.bold {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
.token.italic {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.entity {
|
|
||||||
cursor: help;
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.deleted {
|
|
||||||
color: red;
|
|
||||||
}
|
|
||||||
|
|
||||||
pre.line-numbers {
|
|
||||||
position: relative;
|
|
||||||
padding-left: 3.8em;
|
|
||||||
counter-reset: linenumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
pre.line-numbers > code {
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-numbers .line-numbers-rows {
|
|
||||||
position: absolute;
|
|
||||||
pointer-events: none;
|
|
||||||
top: 0;
|
|
||||||
font-size: 100%;
|
|
||||||
left: -3.8em;
|
|
||||||
width: 3em; /* works for line-numbers below 1000 lines */
|
|
||||||
letter-spacing: -1px;
|
|
||||||
border-right: 1px solid #999;
|
|
||||||
|
|
||||||
-webkit-user-select: none;
|
|
||||||
-moz-user-select: none;
|
|
||||||
-ms-user-select: none;
|
|
||||||
user-select: none;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-numbers-rows > span {
|
|
||||||
pointer-events: none;
|
|
||||||
display: block;
|
|
||||||
counter-increment: linenumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
.line-numbers-rows > span:before {
|
|
||||||
content: counter(linenumber);
|
|
||||||
color: #999;
|
|
||||||
display: block;
|
|
||||||
padding-right: 0.8em;
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
.token.tab:not(:empty):before,
|
|
||||||
.token.cr:before,
|
|
||||||
.token.lf:before {
|
|
||||||
color: hsl(24, 20%, 85%);
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.tab:not(:empty):before {
|
|
||||||
content: '\21E5';
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.cr:before {
|
|
||||||
content: '\240D';
|
|
||||||
}
|
|
||||||
|
|
||||||
.token.crlf:before {
|
|
||||||
content: '\240D\240A';
|
|
||||||
}
|
|
||||||
.token.lf:before {
|
|
||||||
content: '\240A';
|
|
||||||
}
|
|
|
@ -1,15 +0,0 @@
|
||||||
/* http://prismjs.com/download.html?themes=prism-dark&languages=markup+css+clike+javascript+git+http+markdown+php+php-extras+scss+sql&plugins=line-numbers+show-invisibles */
|
|
||||||
var _self="undefined"!=typeof window?window:"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope?self:{},Prism=function(){var e=/\blang(?:uage)?-(?!\*)(\w+)\b/i,t=_self.Prism={util:{encode:function(e){return e instanceof n?new n(e.type,t.util.encode(e.content),e.alias):"Array"===t.util.type(e)?e.map(t.util.encode):e.replace(/&/g,"&").replace(/</g,"<").replace(/\u00a0/g," ")},type:function(e){return Object.prototype.toString.call(e).match(/\[object (\w+)\]/)[1]},clone:function(e){var n=t.util.type(e);switch(n){case"Object":var a={};for(var r in e)e.hasOwnProperty(r)&&(a[r]=t.util.clone(e[r]));return a;case"Array":return e.map&&e.map(function(e){return t.util.clone(e)})}return e}},languages:{extend:function(e,n){var a=t.util.clone(t.languages[e]);for(var r in n)a[r]=n[r];return a},insertBefore:function(e,n,a,r){r=r||t.languages;var i=r[e];if(2==arguments.length){a=arguments[1];for(var l in a)a.hasOwnProperty(l)&&(i[l]=a[l]);return i}var o={};for(var s in i)if(i.hasOwnProperty(s)){if(s==n)for(var l in a)a.hasOwnProperty(l)&&(o[l]=a[l]);o[s]=i[s]}return t.languages.DFS(t.languages,function(t,n){n===r[e]&&t!=e&&(this[t]=o)}),r[e]=o},DFS:function(e,n,a){for(var r in e)e.hasOwnProperty(r)&&(n.call(e,r,e[r],a||r),"Object"===t.util.type(e[r])?t.languages.DFS(e[r],n):"Array"===t.util.type(e[r])&&t.languages.DFS(e[r],n,r))}},highlightAll:function(e,n){for(var a,r=document.querySelectorAll('code[class*="language-"], [class*="language-"] code, code[class*="lang-"], [class*="lang-"] code'),i=0;a=r[i++];)t.highlightElement(a,e===!0,n)},highlightElement:function(a,r,i){for(var l,o,s=a;s&&!e.test(s.className);)s=s.parentNode;s&&(l=(s.className.match(e)||[,""])[1],o=t.languages[l]),a.className=a.className.replace(e,"").replace(/\s+/g," ")+" language-"+l,s=a.parentNode,/pre/i.test(s.nodeName)&&(s.className=s.className.replace(e,"").replace(/\s+/g," ")+" language-"+l);var u=a.textContent,g={element:a,language:l,grammar:o,code:u};if(!u||!o)return t.hooks.run("complete",g),void 0;if(t.hooks.run("before-highlight",g),r&&_self.Worker){var c=new Worker(t.filename);c.onmessage=function(e){g.highlightedCode=n.stringify(JSON.parse(e.data),l),t.hooks.run("before-insert",g),g.element.innerHTML=g.highlightedCode,i&&i.call(g.element),t.hooks.run("after-highlight",g),t.hooks.run("complete",g)},c.postMessage(JSON.stringify({language:g.language,code:g.code}))}else g.highlightedCode=t.highlight(g.code,g.grammar,g.language),t.hooks.run("before-insert",g),g.element.innerHTML=g.highlightedCode,i&&i.call(a),t.hooks.run("after-highlight",g),t.hooks.run("complete",g)},highlight:function(e,a,r){var i=t.tokenize(e,a);return n.stringify(t.util.encode(i),r)},tokenize:function(e,n){var a=t.Token,r=[e],i=n.rest;if(i){for(var l in i)n[l]=i[l];delete n.rest}e:for(var l in n)if(n.hasOwnProperty(l)&&n[l]){var o=n[l];o="Array"===t.util.type(o)?o:[o];for(var s=0;s<o.length;++s){var u=o[s],g=u.inside,c=!!u.lookbehind,f=0,h=u.alias;u=u.pattern||u;for(var p=0;p<r.length;p++){var d=r[p];if(r.length>e.length)break e;if(!(d instanceof a)){u.lastIndex=0;var m=u.exec(d);if(m){c&&(f=m[1].length);var y=m.index-1+f,m=m[0].slice(f),v=m.length,k=y+v,b=d.slice(0,y+1),w=d.slice(k+1),N=[p,1];b&&N.push(b);var O=new a(l,g?t.tokenize(m,g):m,h);N.push(O),w&&N.push(w),Array.prototype.splice.apply(r,N)}}}}}return r},hooks:{all:{},add:function(e,n){var a=t.hooks.all;a[e]=a[e]||[],a[e].push(n)},run:function(e,n){var a=t.hooks.all[e];if(a&&a.length)for(var r,i=0;r=a[i++];)r(n)}}},n=t.Token=function(e,t,n){this.type=e,this.content=t,this.alias=n};if(n.stringify=function(e,a,r){if("string"==typeof e)return e;if("Array"===t.util.type(e))return e.map(function(t){return n.stringify(t,a,e)}).join("");var i={type:e.type,content:n.stringify(e.content,a,r),tag:"span",classes:["token",e.type],attributes:{},language:a,parent:r};if("comment"==i.type&&(i.attributes.spellcheck="true"),e.alias){var l="Array"===t.util.type(e.alias)?e.alias:[e.alias];Array.prototype.push.apply(i.classes,l)}t.hooks.run("wrap",i);var o="";for(var s in i.attributes)o+=s+'="'+(i.attributes[s]||"")+'"';return"<"+i.tag+' class="'+i.classes.join(" ")+'" '+o+">"+i.content+"</"+i.tag+">"},!_self.document)return _self.addEventListener?(_self.addEventListener("message",function(e){var n=JSON.parse(e.data),a=n.language,r=n.code;_self.postMessage(JSON.stringify(t.util.encode(t.tokenize(r,t.languages[a])))),_self.close()},!1),_self.Prism):_self.Prism;var a=document.getElementsByTagName("script");return a=a[a.length-1],a&&(t.filename=a.src,document.addEventListener&&!a.hasAttribute("data-manual")&&document.addEventListener("DOMContentLoaded",t.highlightAll)),_self.Prism}();"undefined"!=typeof module&&module.exports&&(module.exports=Prism);;
|
|
||||||
Prism.languages.markup={comment:/<!--[\w\W]*?-->/,prolog:/<\?[\w\W]+?\?>/,doctype:/<!DOCTYPE[\w\W]+?>/,cdata:/<!\[CDATA\[[\w\W]*?]]>/i,tag:{pattern:/<\/?[^\s>\/]+(?:\s+[^\s>\/=]+(?:=(?:("|')(?:\\\1|\\?(?!\1)[\w\W])*\1|[^\s'">=]+))?)*\s*\/?>/i,inside:{tag:{pattern:/^<\/?[^\s>\/]+/i,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"attr-value":{pattern:/=(?:('|")[\w\W]*?(\1)|[^\s>]+)/i,inside:{punctuation:/[=>"']/}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:/&#?[\da-z]{1,8};/i},Prism.hooks.add("wrap",function(t){"entity"===t.type&&(t.attributes.title=t.content.replace(/&/,"&"))});;
|
|
||||||
Prism.languages.css={comment:/\/\*[\w\W]*?\*\//,atrule:{pattern:/@[\w-]+?.*?(;|(?=\s*\{))/i,inside:{rule:/@[\w-]+/}},url:/url\((?:(["'])(\\(?:\r\n|[\w\W])|(?!\1)[^\\\r\n])*\1|.*?)\)/i,selector:/[^\{\}\s][^\{\};]*?(?=\s*\{)/,string:/("|')(\\(?:\r\n|[\w\W])|(?!\1)[^\\\r\n])*\1/,property:/(\b|\B)[\w-]+(?=\s*:)/i,important:/\B!important\b/i,"function":/[-a-z0-9]+(?=\()/i,punctuation:/[(){};:]/},Prism.languages.css.atrule.inside.rest=Prism.util.clone(Prism.languages.css),Prism.languages.markup&&(Prism.languages.insertBefore("markup","tag",{style:{pattern:/<style[\w\W]*?>[\w\W]*?<\/style>/i,inside:{tag:{pattern:/<style[\w\W]*?>|<\/style>/i,inside:Prism.languages.markup.tag.inside},rest:Prism.languages.css},alias:"language-css"}}),Prism.languages.insertBefore("inside","attr-value",{"style-attr":{pattern:/\s*style=("|').*?\1/i,inside:{"attr-name":{pattern:/^\s*style/i,inside:Prism.languages.markup.tag.inside},punctuation:/^\s*=\s*['"]|['"]\s*$/,"attr-value":{pattern:/.+/i,inside:Prism.languages.css}},alias:"language-css"}},Prism.languages.markup.tag));;
|
|
||||||
Prism.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\w\W]*?\*\//,lookbehind:!0},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:!0}],string:/("|')(\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,"class-name":{pattern:/((?:\b(?:class|interface|extends|implements|trait|instanceof|new)\s+)|(?:catch\s+\())[a-z0-9_\.\\]+/i,lookbehind:!0,inside:{punctuation:/(\.|\\)/}},keyword:/\b(if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/,"boolean":/\b(true|false)\b/,"function":/[a-z0-9_]+(?=\()/i,number:/\b-?(0x[\dA-Fa-f]+|\d*\.?\d+([Ee]-?\d+)?)\b/,operator:/[-+]{1,2}|!|<=?|>=?|={1,3}|&{1,2}|\|?\||\?|\*|\/|~|\^|%/,punctuation:/[{}[\];(),.:]/};;
|
|
||||||
Prism.languages.javascript=Prism.languages.extend("clike",{keyword:/\b(as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|false|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|true|try|typeof|var|void|while|with|yield)\b/,number:/\b-?(0x[\dA-Fa-f]+|0b[01]+|0o[0-7]+|\d*\.?\d+([Ee][+-]?\d+)?|NaN|Infinity)\b/,"function":/(?!\d)[a-z0-9_$]+(?=\()/i}),Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:/(^|[^/])\/(?!\/)(\[.+?]|\\.|[^/\\\r\n])+\/[gimyu]{0,5}(?=\s*($|[\r\n,.;})]))/,lookbehind:!0}}),Prism.languages.insertBefore("javascript","class-name",{"template-string":{pattern:/`(?:\\`|\\?[^`])*`/,inside:{interpolation:{pattern:/\$\{[^}]+\}/,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}}}),Prism.languages.markup&&Prism.languages.insertBefore("markup","tag",{script:{pattern:/<script[\w\W]*?>[\w\W]*?<\/script>/i,inside:{tag:{pattern:/<script[\w\W]*?>|<\/script>/i,inside:Prism.languages.markup.tag.inside},rest:Prism.languages.javascript},alias:"language-javascript"}});;
|
|
||||||
Prism.languages.git={comment:/^#.*$/m,string:/("|')(\\?.)*?\1/m,command:{pattern:/^.*\$ git .*$/m,inside:{parameter:/\s(--|-)\w+/m}},coord:/^@@.*@@$/m,deleted:/^-(?!-).+$/m,inserted:/^\+(?!\+).+$/m,commit_sha1:/^commit \w{40}$/m};;
|
|
||||||
Prism.languages.http={"request-line":{pattern:/^(POST|GET|PUT|DELETE|OPTIONS|PATCH|TRACE|CONNECT)\b\shttps?:\/\/\S+\sHTTP\/[0-9.]+/,inside:{property:/^\b(POST|GET|PUT|DELETE|OPTIONS|PATCH|TRACE|CONNECT)\b/,"attr-name":/:\w+/}},"response-status":{pattern:/^HTTP\/1.[01] [0-9]+.*/,inside:{property:/[0-9]+[A-Z\s-]+$/i}},keyword:/^[\w-]+:(?=.+)/m};var httpLanguages={"application/json":Prism.languages.javascript,"application/xml":Prism.languages.markup,"text/xml":Prism.languages.markup,"text/html":Prism.languages.markup};for(var contentType in httpLanguages)if(httpLanguages[contentType]){var options={};options[contentType]={pattern:new RegExp("(content-type:\\s*"+contentType+"[\\w\\W]*?)\\n\\n[\\w\\W]*","i"),lookbehind:!0,inside:{rest:httpLanguages[contentType]}},Prism.languages.insertBefore("http","keyword",options)};
|
|
||||||
Prism.languages.markdown=Prism.languages.extend("markup",{}),Prism.languages.insertBefore("markdown","prolog",{blockquote:{pattern:/(^|\n)>(?:[\t ]*>)*/,lookbehind:!0,alias:"punctuation"},code:[{pattern:/(^|\n)(?: {4}|\t).+/,lookbehind:!0,alias:"keyword"},{pattern:/``.+?``|`[^`\n]+`/,alias:"keyword"}],title:[{pattern:/\w+.*\n(?:==+|--+)/,alias:"important",inside:{punctuation:/==+$|--+$/}},{pattern:/((?:^|\n)\s*)#+.+/,lookbehind:!0,alias:"important",inside:{punctuation:/^#+|#+$/}}],hr:{pattern:/((?:^|\n)\s*)([*-])([\t ]*\2){2,}(?=\s*(?:\n|$))/,lookbehind:!0,alias:"punctuation"},list:{pattern:/((?:^|\n)\s*)(?:[*+-]|\d+\.)(?=[\t ].)/,lookbehind:!0,alias:"punctuation"},"url-reference":{pattern:/!?\[[^\]]+\]:[\t ]+(?:\S+|<(?:[^>]|\\>)+>)(?:[\t ]+(?:"(?:[^"]|\\")*"|'(?:[^']|\\')*'|\((?:[^)]|\\\))*\)))?/,inside:{variable:{pattern:/^(!?\[)[^\]]+/,lookbehind:!0},string:/(?:"(?:[^"]|\\")*"|'(?:[^']|\\')*'|\((?:[^)]|\\\))*\))$/,punctuation:/[[\]\(\)<>:]/},alias:"url"},bold:{pattern:/(^|[^\\])(\*\*|__)(?:\n(?!\n)|.)+?\2/,lookbehind:!0,inside:{punctuation:/^\*\*|^__|\*\*\s*$|__\s*$/}},italic:{pattern:/(^|[^\\])(?:\*(?:\n(?!\n)|.)+?\*|_(?:\n(?!\n)|.)+?_)/,lookbehind:!0,inside:{punctuation:/^[*_]|[*_]$/}},url:{pattern:/!?\[[^\]]+\](?:\([^\s)]+(?:[\t ]+"(?:[^"]|\\")*")?\)| ?\[[^\]\n]*\])/,inside:{variable:{pattern:/(!?\[)[^\]]+(?=\]$)/,lookbehind:!0},string:{pattern:/"(?:[^"]|\\")*"(?=\)$)/}}}}),Prism.languages.markdown.bold.inside.url=Prism.util.clone(Prism.languages.markdown.url),Prism.languages.markdown.italic.inside.url=Prism.util.clone(Prism.languages.markdown.url),Prism.languages.markdown.bold.inside.italic=Prism.util.clone(Prism.languages.markdown.italic),Prism.languages.markdown.italic.inside.bold=Prism.util.clone(Prism.languages.markdown.bold);;
|
|
||||||
Prism.languages.php=Prism.languages.extend("clike",{keyword:/\b(and|or|xor|array|as|break|case|cfunction|class|const|continue|declare|default|die|do|else|elseif|enddeclare|endfor|endforeach|endif|endswitch|endwhile|extends|for|foreach|function|include|include_once|global|if|new|return|static|switch|use|require|require_once|var|while|abstract|interface|public|implements|private|protected|parent|throw|null|echo|print|trait|namespace|final|yield|goto|instanceof|finally|try|catch)\b/i,constant:/\b[A-Z0-9_]{2,}\b/,comment:{pattern:/(^|[^\\])(\/\*[\w\W]*?\*\/|(^|[^:])(\/\/).*?(\r?\n|$))/,lookbehind:!0}}),Prism.languages.insertBefore("php","class-name",{"shell-comment":{pattern:/(^|[^\\])#.*?(\r?\n|$)/,lookbehind:!0,alias:"comment"}}),Prism.languages.insertBefore("php","keyword",{delimiter:/(\?>|<\?php|<\?)/i,variable:/(\$\w+)\b/i,"package":{pattern:/(\\|namespace\s+|use\s+)[\w\\]+/,lookbehind:!0,inside:{punctuation:/\\/}}}),Prism.languages.insertBefore("php","operator",{property:{pattern:/(->)[\w]+/,lookbehind:!0}}),Prism.languages.markup&&(Prism.hooks.add("before-highlight",function(e){"php"===e.language&&(e.tokenStack=[],e.backupCode=e.code,e.code=e.code.replace(/(?:<\?php|<\?)[\w\W]*?(?:\?>)/gi,function(n){return e.tokenStack.push(n),"{{{PHP"+e.tokenStack.length+"}}}"}))}),Prism.hooks.add("before-insert",function(e){"php"===e.language&&(e.code=e.backupCode,delete e.backupCode)}),Prism.hooks.add("after-highlight",function(e){if("php"===e.language){for(var n,a=0;n=e.tokenStack[a];a++)e.highlightedCode=e.highlightedCode.replace("{{{PHP"+(a+1)+"}}}",Prism.highlight(n,e.grammar,"php"));e.element.innerHTML=e.highlightedCode}}),Prism.hooks.add("wrap",function(e){"php"===e.language&&"markup"===e.type&&(e.content=e.content.replace(/(\{\{\{PHP[0-9]+\}\}\})/g,'<span class="token php">$1</span>'))}),Prism.languages.insertBefore("php","comment",{markup:{pattern:/<[^?]\/?(.*?)>/,inside:Prism.languages.markup},php:/\{\{\{PHP[0-9]+\}\}\}/}));;
|
|
||||||
Prism.languages.insertBefore("php","variable",{"this":/\$this/,global:/\$_?(GLOBALS|SERVER|GET|POST|FILES|REQUEST|SESSION|ENV|COOKIE|HTTP_RAW_POST_DATA|argc|argv|php_errormsg|http_response_header)/,scope:{pattern:/\b[\w\\]+::/,inside:{keyword:/(static|self|parent)/,punctuation:/(::|\\)/}}});;
|
|
||||||
Prism.languages.scss=Prism.languages.extend("css",{comment:{pattern:/(^|[^\\])(\/\*[\w\W]*?\*\/|\/\/.*?(\r?\n|$))/,lookbehind:!0},atrule:{pattern:/@[\w-]+(?:\([^()]+\)|[^(])*?(?=\s+(\{|;))/i,inside:{rule:/@[\w-]+/}},url:/([-a-z]+-)*url(?=\()/i,selector:{pattern:/([^@;\{\}\(\)]?([^@;\{\}\(\)]|&|#\{\$[-_\w]+\})+)(?=\s*\{(\}|\s|[^\}]+(:|\{)[^\}]+))/m,inside:{placeholder:/%[-_\w]+/i}}}),Prism.languages.insertBefore("scss","atrule",{keyword:/@(if|else if|else|for|each|while|import|extend|debug|warn|mixin|include|function|return|content)|(?=@for\s+\$[-_\w]+\s)+from/i}),Prism.languages.insertBefore("scss","property",{variable:/((\$[-_\w]+)|(#\{\$[-_\w]+\}))/i}),Prism.languages.insertBefore("scss","function",{placeholder:{pattern:/%[-_\w]+/i,alias:"selector"},statement:/\B!(default|optional)\b/i,"boolean":/\b(true|false)\b/,"null":/\b(null)\b/,operator:/\s+([-+]{1,2}|={1,2}|!=|\|?\||\?|\*|\/|%)\s+/}),Prism.languages.scss.atrule.inside.rest=Prism.util.clone(Prism.languages.scss);;
|
|
||||||
Prism.languages.sql={comment:{pattern:/(^|[^\\])(\/\*[\w\W]*?\*\/|((--)|(\/\/)|#).*?(\r?\n|$))/,lookbehind:!0},string:{pattern:/(^|[^@])("|')(\\?[\s\S])*?\2/,lookbehind:!0},variable:/@[\w.$]+|@("|'|`)(\\?[\s\S])+?\1/,"function":/\b(?:COUNT|SUM|AVG|MIN|MAX|FIRST|LAST|UCASE|LCASE|MID|LEN|ROUND|NOW|FORMAT)(?=\s*\()/i,keyword:/\b(?:ACTION|ADD|AFTER|ALGORITHM|ALTER|ANALYZE|APPLY|AS|ASC|AUTHORIZATION|BACKUP|BDB|BEGIN|BERKELEYDB|BIGINT|BINARY|BIT|BLOB|BOOL|BOOLEAN|BREAK|BROWSE|BTREE|BULK|BY|CALL|CASCADE|CASCADED|CASE|CHAIN|CHAR VARYING|CHARACTER VARYING|CHECK|CHECKPOINT|CLOSE|CLUSTERED|COALESCE|COLUMN|COLUMNS|COMMENT|COMMIT|COMMITTED|COMPUTE|CONNECT|CONSISTENT|CONSTRAINT|CONTAINS|CONTAINSTABLE|CONTINUE|CONVERT|CREATE|CROSS|CURRENT|CURRENT_DATE|CURRENT_TIME|CURRENT_TIMESTAMP|CURRENT_USER|CURSOR|DATA|DATABASE|DATABASES|DATETIME|DBCC|DEALLOCATE|DEC|DECIMAL|DECLARE|DEFAULT|DEFINER|DELAYED|DELETE|DENY|DESC|DESCRIBE|DETERMINISTIC|DISABLE|DISCARD|DISK|DISTINCT|DISTINCTROW|DISTRIBUTED|DO|DOUBLE|DOUBLE PRECISION|DROP|DUMMY|DUMP|DUMPFILE|DUPLICATE KEY|ELSE|ENABLE|ENCLOSED BY|END|ENGINE|ENUM|ERRLVL|ERRORS|ESCAPE|ESCAPED BY|EXCEPT|EXEC|EXECUTE|EXIT|EXPLAIN|EXTENDED|FETCH|FIELDS|FILE|FILLFACTOR|FIRST|FIXED|FLOAT|FOLLOWING|FOR|FOR EACH ROW|FORCE|FOREIGN|FREETEXT|FREETEXTTABLE|FROM|FULL|FUNCTION|GEOMETRY|GEOMETRYCOLLECTION|GLOBAL|GOTO|GRANT|GROUP|HANDLER|HASH|HAVING|HOLDLOCK|IDENTITY|IDENTITY_INSERT|IDENTITYCOL|IF|IGNORE|IMPORT|INDEX|INFILE|INNER|INNODB|INOUT|INSERT|INT|INTEGER|INTERSECT|INTO|INVOKER|ISOLATION LEVEL|JOIN|KEY|KEYS|KILL|LANGUAGE SQL|LAST|LEFT|LIMIT|LINENO|LINES|LINESTRING|LOAD|LOCAL|LOCK|LONGBLOB|LONGTEXT|MATCH|MATCHED|MEDIUMBLOB|MEDIUMINT|MEDIUMTEXT|MERGE|MIDDLEINT|MODIFIES SQL DATA|MODIFY|MULTILINESTRING|MULTIPOINT|MULTIPOLYGON|NATIONAL|NATIONAL CHAR VARYING|NATIONAL CHARACTER|NATIONAL CHARACTER VARYING|NATIONAL VARCHAR|NATURAL|NCHAR|NCHAR VARCHAR|NEXT|NO|NO SQL|NOCHECK|NOCYCLE|NONCLUSTERED|NULLIF|NUMERIC|OF|OFF|OFFSETS|ON|OPEN|OPENDATASOURCE|OPENQUERY|OPENROWSET|OPTIMIZE|OPTION|OPTIONALLY|ORDER|OUT|OUTER|OUTFILE|OVER|PARTIAL|PARTITION|PERCENT|PIVOT|PLAN|POINT|POLYGON|PRECEDING|PRECISION|PREV|PRIMARY|PRINT|PRIVILEGES|PROC|PROCEDURE|PUBLIC|PURGE|QUICK|RAISERROR|READ|READS SQL DATA|READTEXT|REAL|RECONFIGURE|REFERENCES|RELEASE|RENAME|REPEATABLE|REPLICATION|REQUIRE|RESTORE|RESTRICT|RETURN|RETURNS|REVOKE|RIGHT|ROLLBACK|ROUTINE|ROWCOUNT|ROWGUIDCOL|ROWS?|RTREE|RULE|SAVE|SAVEPOINT|SCHEMA|SELECT|SERIAL|SERIALIZABLE|SESSION|SESSION_USER|SET|SETUSER|SHARE MODE|SHOW|SHUTDOWN|SIMPLE|SMALLINT|SNAPSHOT|SOME|SONAME|START|STARTING BY|STATISTICS|STATUS|STRIPED|SYSTEM_USER|TABLE|TABLES|TABLESPACE|TEMP(?:ORARY)?|TEMPTABLE|TERMINATED BY|TEXT|TEXTSIZE|THEN|TIMESTAMP|TINYBLOB|TINYINT|TINYTEXT|TO|TOP|TRAN|TRANSACTION|TRANSACTIONS|TRIGGER|TRUNCATE|TSEQUAL|TYPE|TYPES|UNBOUNDED|UNCOMMITTED|UNDEFINED|UNION|UNPIVOT|UPDATE|UPDATETEXT|USAGE|USE|USER|USING|VALUE|VALUES|VARBINARY|VARCHAR|VARCHARACTER|VARYING|VIEW|WAITFOR|WARNINGS|WHEN|WHERE|WHILE|WITH|WITH ROLLUP|WITHIN|WORK|WRITE|WRITETEXT)\b/i,"boolean":/\b(?:TRUE|FALSE|NULL)\b/i,number:/\b-?(0x)?\d*\.?[\da-f]+\b/,operator:/\b(?:ALL|AND|ANY|BETWEEN|EXISTS|IN|LIKE|NOT|OR|IS|UNIQUE|CHARACTER SET|COLLATE|DIV|OFFSET|REGEXP|RLIKE|SOUNDS LIKE|XOR)\b|[-+]|!|[=<>]{1,2}|(&){1,2}|\|?\||\?|\*|\//i,punctuation:/[;[\]()`,.]/};;
|
|
||||||
Prism.hooks.add("complete",function(e){if(e.code){var t=e.element.parentNode,s=/\s*\bline-numbers\b\s*/;if(t&&/pre/i.test(t.nodeName)&&(s.test(t.className)||s.test(e.element.className))&&!e.element.querySelector(".line-numbers-rows")){s.test(e.element.className)&&(e.element.className=e.element.className.replace(s,"")),s.test(t.className)||(t.className+=" line-numbers");var a,n=e.code.match(/\n(?!$)/g).length+1,l=new Array(n+1);l=l.join("<span></span>"),a=document.createElement("span"),a.className="line-numbers-rows",a.innerHTML=l,t.hasAttribute("data-start")&&(t.style.counterReset="linenumber "+(parseInt(t.getAttribute("data-start"),10)-1)),e.element.appendChild(a)}}});;
|
|
||||||
!function(){if(window.Prism)for(var r in Prism.languages){var g=Prism.languages[r];g.tab=/\t/g,g.crlf=/\r\n/g,g.lf=/\n/g,g.cr=/\r/g}}();;
|
|
|
@ -1,18 +0,0 @@
|
||||||
{
|
|
||||||
"assets/bower/Autolinker.min.js": "assets/bower/Autolinker-2cb3468034.min.js",
|
|
||||||
"assets/bower/alertify.css": "assets/bower/alertify-1b3c6aa174.css",
|
|
||||||
"assets/bower/alertify.js": "assets/bower/alertify-84061c87f5.js",
|
|
||||||
"assets/bower/fetch.js": "assets/bower/fetch-d8a2646ccc.js",
|
|
||||||
"assets/bower/marked.min.js": "assets/bower/marked-c2a88705e2.min.js",
|
|
||||||
"assets/bower/sanitize.css": "assets/bower/sanitize-85919f917a.css",
|
|
||||||
"assets/bower/store2.min.js": "assets/bower/store2-c4daa8f871.min.js",
|
|
||||||
"assets/css/global.css": "assets/css/global-5eaecdf53d.css",
|
|
||||||
"assets/css/projects.css": "assets/css/projects-d945298e4f.css",
|
|
||||||
"assets/js/form-save.js": "assets/js/form-save-4d4f6e1cb8.js",
|
|
||||||
"assets/js/links.js": "assets/js/links-c394f9c920.js",
|
|
||||||
"assets/js/maps.js": "assets/js/maps-a6a01a253b.js",
|
|
||||||
"assets/js/newnote.js": "assets/js/newnote-36ff29cdef.js",
|
|
||||||
"assets/js/newplace.js": "assets/js/newplace-89a1be080e.js",
|
|
||||||
"assets/prism/prism.css": "assets/prism/prism-5c98941a94.css",
|
|
||||||
"assets/prism/prism.js": "assets/prism/prism-f6e997bc6d.js"
|
|
||||||
}
|
|
Loading…
Add table
Add a link
Reference in a new issue