Cleaning Clean Blog
This commit is contained in:
parent
0fdfff1e67
commit
d4f1f078cc
|
@ -0,0 +1,3 @@
|
||||||
|
img {
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
|
@ -1,351 +0,0 @@
|
||||||
/*!
|
|
||||||
* Start Bootstrap - Clean Blog v4.0.0-beta (https://startbootstrap.com/template-overviews/clean-blog)
|
|
||||||
* Copyright 2013-2017 Start Bootstrap
|
|
||||||
* Licensed under MIT (https://github.com/BlackrockDigital/startbootstrap-clean-blog/blob/master/LICENSE)
|
|
||||||
*/
|
|
||||||
body {
|
|
||||||
font-size: 20px;
|
|
||||||
color: #333333;
|
|
||||||
font-family: 'Lora', 'Times New Roman', serif; }
|
|
||||||
|
|
||||||
p {
|
|
||||||
line-height: 1.5;
|
|
||||||
margin: 30px 0; }
|
|
||||||
p a {
|
|
||||||
text-decoration: underline; }
|
|
||||||
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3,
|
|
||||||
h4,
|
|
||||||
h5,
|
|
||||||
h6 {
|
|
||||||
font-weight: 800;
|
|
||||||
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif; }
|
|
||||||
|
|
||||||
a {
|
|
||||||
color: #333333;
|
|
||||||
-webkit-transition: all 0.2s;
|
|
||||||
-moz-transition: all 0.2s;
|
|
||||||
transition: all 0.2s; }
|
|
||||||
a:focus, a:hover {
|
|
||||||
color: #0085A1; }
|
|
||||||
|
|
||||||
a img:focus, a img:hover {
|
|
||||||
cursor: zoom-in; }
|
|
||||||
|
|
||||||
blockquote {
|
|
||||||
font-style: italic;
|
|
||||||
color: #777777; }
|
|
||||||
|
|
||||||
.section-heading {
|
|
||||||
font-size: 36px;
|
|
||||||
font-weight: 700;
|
|
||||||
margin-top: 60px; }
|
|
||||||
|
|
||||||
.caption {
|
|
||||||
font-size: 14px;
|
|
||||||
font-style: italic;
|
|
||||||
display: block;
|
|
||||||
margin: 0;
|
|
||||||
padding: 10px;
|
|
||||||
text-align: center;
|
|
||||||
border-bottom-right-radius: 5px;
|
|
||||||
border-bottom-left-radius: 5px; }
|
|
||||||
|
|
||||||
::-moz-selection {
|
|
||||||
color: white;
|
|
||||||
background: #0085A1;
|
|
||||||
text-shadow: none; }
|
|
||||||
|
|
||||||
::selection {
|
|
||||||
color: white;
|
|
||||||
background: #0085A1;
|
|
||||||
text-shadow: none; }
|
|
||||||
|
|
||||||
img::selection {
|
|
||||||
color: white;
|
|
||||||
background: transparent; }
|
|
||||||
|
|
||||||
img::-moz-selection {
|
|
||||||
color: white;
|
|
||||||
background: transparent; }
|
|
||||||
|
|
||||||
body {
|
|
||||||
-webkit-tap-highlight-color: #0085A1; }
|
|
||||||
|
|
||||||
#mainNav {
|
|
||||||
position: absolute;
|
|
||||||
border-bottom: 1px solid #eeeeee;
|
|
||||||
background-color: white;
|
|
||||||
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif; }
|
|
||||||
#mainNav .navbar-brand {
|
|
||||||
font-weight: 800;
|
|
||||||
color: #777777; }
|
|
||||||
#mainNav .navbar-toggler {
|
|
||||||
font-size: 12px;
|
|
||||||
font-weight: 800;
|
|
||||||
padding: 13px;
|
|
||||||
text-transform: uppercase;
|
|
||||||
color: #777777; }
|
|
||||||
#mainNav .navbar-nav > li.nav-item > a {
|
|
||||||
font-size: 12px;
|
|
||||||
font-weight: 800;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
text-transform: uppercase; }
|
|
||||||
@media only screen and (min-width: 992px) {
|
|
||||||
#mainNav {
|
|
||||||
border-bottom: 1px solid transparent;
|
|
||||||
background: transparent; }
|
|
||||||
#mainNav .navbar-brand {
|
|
||||||
padding: 15px 20px;
|
|
||||||
color: white; }
|
|
||||||
#mainNav .navbar-brand:focus, #mainNav .navbar-brand:hover {
|
|
||||||
color: rgba(255, 255, 255, 0.8); }
|
|
||||||
#mainNav .navbar-nav > li.nav-item > a {
|
|
||||||
padding: 15px 20px;
|
|
||||||
color: white; }
|
|
||||||
#mainNav .navbar-nav > li.nav-item > a:focus, #mainNav .navbar-nav > li.nav-item > a:hover {
|
|
||||||
color: rgba(255, 255, 255, 0.8); } }
|
|
||||||
@media only screen and (min-width: 1170px) {
|
|
||||||
#mainNav {
|
|
||||||
-webkit-transition: background-color 0.2s;
|
|
||||||
-moz-transition: background-color 0.2s;
|
|
||||||
transition: background-color 0.2s;
|
|
||||||
/* Force Hardware Acceleration in WebKit */
|
|
||||||
-webkit-transform: translate3d(0, 0, 0);
|
|
||||||
-moz-transform: translate3d(0, 0, 0);
|
|
||||||
-ms-transform: translate3d(0, 0, 0);
|
|
||||||
-o-transform: translate3d(0, 0, 0);
|
|
||||||
transform: translate3d(0, 0, 0);
|
|
||||||
-webkit-backface-visibility: hidden; }
|
|
||||||
#mainNav.is-fixed {
|
|
||||||
/* when the user scrolls down, we hide the header right above the viewport */
|
|
||||||
position: fixed;
|
|
||||||
top: -77px;
|
|
||||||
-webkit-transition: -webkit-transform 0.2s;
|
|
||||||
-moz-transition: -moz-transform 0.2s;
|
|
||||||
transition: transform 0.2s;
|
|
||||||
border-bottom: 1px solid white;
|
|
||||||
background-color: rgba(255, 255, 255, 0.9); }
|
|
||||||
#mainNav.is-fixed .navbar-brand {
|
|
||||||
color: #333333; }
|
|
||||||
#mainNav.is-fixed .navbar-brand:focus, #mainNav.is-fixed .navbar-brand:hover {
|
|
||||||
color: #0085A1; }
|
|
||||||
#mainNav.is-fixed .navbar-nav > li.nav-item > a {
|
|
||||||
color: #333333; }
|
|
||||||
#mainNav.is-fixed .navbar-nav > li.nav-item > a:focus, #mainNav.is-fixed .navbar-nav > li.nav-item > a:hover {
|
|
||||||
color: #0085A1; }
|
|
||||||
#mainNav.is-visible {
|
|
||||||
/* if the user changes the scrolling direction, we show the header */
|
|
||||||
-webkit-transform: translate3d(0, 100%, 0);
|
|
||||||
-moz-transform: translate3d(0, 100%, 0);
|
|
||||||
-ms-transform: translate3d(0, 100%, 0);
|
|
||||||
-o-transform: translate3d(0, 100%, 0);
|
|
||||||
transform: translate3d(0, 100%, 0); } }
|
|
||||||
|
|
||||||
header.masthead {
|
|
||||||
margin-bottom: 50px;
|
|
||||||
background: no-repeat center center;
|
|
||||||
background-color: #777777;
|
|
||||||
background-attachment: scroll;
|
|
||||||
-webkit-background-size: cover;
|
|
||||||
-moz-background-size: cover;
|
|
||||||
-o-background-size: cover;
|
|
||||||
background-size: cover; }
|
|
||||||
header.masthead .page-heading,
|
|
||||||
header.masthead .post-heading,
|
|
||||||
header.masthead .site-heading {
|
|
||||||
padding: 200px 0 150px;
|
|
||||||
color: white; }
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
header.masthead .page-heading,
|
|
||||||
header.masthead .post-heading,
|
|
||||||
header.masthead .site-heading {
|
|
||||||
padding: 200px 0; } }
|
|
||||||
header.masthead .page-heading,
|
|
||||||
header.masthead .site-heading {
|
|
||||||
text-align: center; }
|
|
||||||
header.masthead .page-heading h1,
|
|
||||||
header.masthead .site-heading h1 {
|
|
||||||
font-size: 50px;
|
|
||||||
margin-top: 0; }
|
|
||||||
header.masthead .page-heading .subheading,
|
|
||||||
header.masthead .site-heading .subheading {
|
|
||||||
font-size: 24px;
|
|
||||||
font-weight: 300;
|
|
||||||
line-height: 1.1;
|
|
||||||
display: block;
|
|
||||||
margin: 10px 0 0;
|
|
||||||
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif; }
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
header.masthead .page-heading h1,
|
|
||||||
header.masthead .site-heading h1 {
|
|
||||||
font-size: 80px; } }
|
|
||||||
header.masthead .post-heading h1 {
|
|
||||||
font-size: 35px; }
|
|
||||||
header.masthead .post-heading .meta,
|
|
||||||
header.masthead .post-heading .subheading {
|
|
||||||
line-height: 1.1;
|
|
||||||
display: block; }
|
|
||||||
header.masthead .post-heading .subheading {
|
|
||||||
font-size: 24px;
|
|
||||||
font-weight: 600;
|
|
||||||
margin: 10px 0 30px;
|
|
||||||
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif; }
|
|
||||||
header.masthead .post-heading .meta {
|
|
||||||
font-size: 20px;
|
|
||||||
font-weight: 300;
|
|
||||||
font-style: italic;
|
|
||||||
font-family: 'Lora', 'Times New Roman', serif; }
|
|
||||||
header.masthead .post-heading .meta a {
|
|
||||||
color: white; }
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
header.masthead .post-heading h1 {
|
|
||||||
font-size: 55px; }
|
|
||||||
header.masthead .post-heading .subheading {
|
|
||||||
font-size: 30px; } }
|
|
||||||
|
|
||||||
.post-preview > a {
|
|
||||||
color: #333333; }
|
|
||||||
.post-preview > a:focus, .post-preview > a:hover {
|
|
||||||
text-decoration: none;
|
|
||||||
color: #0085A1; }
|
|
||||||
.post-preview > a > .post-title {
|
|
||||||
font-size: 30px;
|
|
||||||
margin-top: 30px;
|
|
||||||
margin-bottom: 10px; }
|
|
||||||
.post-preview > a > .post-subtitle {
|
|
||||||
font-weight: 300;
|
|
||||||
margin: 0 0 10px; }
|
|
||||||
|
|
||||||
.post-preview > .post-meta {
|
|
||||||
font-size: 18px;
|
|
||||||
font-style: italic;
|
|
||||||
margin-top: 0;
|
|
||||||
color: #777777; }
|
|
||||||
.post-preview > .post-meta > a {
|
|
||||||
text-decoration: none;
|
|
||||||
color: #333333; }
|
|
||||||
.post-preview > .post-meta > a:focus, .post-preview > .post-meta > a:hover {
|
|
||||||
text-decoration: underline;
|
|
||||||
color: #0085A1; }
|
|
||||||
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
.post-preview > a > .post-title {
|
|
||||||
font-size: 36px; } }
|
|
||||||
|
|
||||||
.floating-label-form-group {
|
|
||||||
font-size: 14px;
|
|
||||||
position: relative;
|
|
||||||
margin-bottom: 0;
|
|
||||||
padding-bottom: 0.5em;
|
|
||||||
border-bottom: 1px solid #eeeeee; }
|
|
||||||
.floating-label-form-group input,
|
|
||||||
.floating-label-form-group textarea {
|
|
||||||
font-size: 1.5em;
|
|
||||||
position: relative;
|
|
||||||
z-index: 1;
|
|
||||||
padding: 0;
|
|
||||||
resize: none;
|
|
||||||
border: none;
|
|
||||||
border-radius: 0;
|
|
||||||
background: none;
|
|
||||||
box-shadow: none !important;
|
|
||||||
font-family: 'Lora', 'Times New Roman', serif; }
|
|
||||||
.floating-label-form-group input::-webkit-input-placeholder,
|
|
||||||
.floating-label-form-group textarea::-webkit-input-placeholder {
|
|
||||||
color: #777777;
|
|
||||||
font-family: 'Lora', 'Times New Roman', serif; }
|
|
||||||
.floating-label-form-group label {
|
|
||||||
font-size: 0.85em;
|
|
||||||
line-height: 1.764705882em;
|
|
||||||
position: relative;
|
|
||||||
z-index: 0;
|
|
||||||
top: 2em;
|
|
||||||
display: block;
|
|
||||||
margin: 0;
|
|
||||||
-webkit-transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
-moz-transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
-ms-transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
vertical-align: middle;
|
|
||||||
vertical-align: baseline;
|
|
||||||
opacity: 0; }
|
|
||||||
.floating-label-form-group .help-block {
|
|
||||||
margin: 15px 0; }
|
|
||||||
|
|
||||||
.floating-label-form-group-with-value label {
|
|
||||||
top: 0;
|
|
||||||
opacity: 1; }
|
|
||||||
|
|
||||||
.floating-label-form-group-with-focus label {
|
|
||||||
color: #0085A1; }
|
|
||||||
|
|
||||||
form .form-group:first-child .floating-label-form-group {
|
|
||||||
border-top: 1px solid #eeeeee; }
|
|
||||||
|
|
||||||
footer {
|
|
||||||
padding: 50px 0 65px; }
|
|
||||||
footer .list-inline {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0; }
|
|
||||||
footer .copyright {
|
|
||||||
font-size: 14px;
|
|
||||||
margin-bottom: 0;
|
|
||||||
text-align: center; }
|
|
||||||
|
|
||||||
.btn {
|
|
||||||
font-size: 14px;
|
|
||||||
font-weight: 800;
|
|
||||||
padding: 15px 25px;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
text-transform: uppercase;
|
|
||||||
border-radius: 0;
|
|
||||||
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif; }
|
|
||||||
|
|
||||||
.btn-primary {
|
|
||||||
color: white;
|
|
||||||
border-color: #0085A1;
|
|
||||||
background-color: #0085A1; }
|
|
||||||
.btn-primary.focus, .btn-primary:focus {
|
|
||||||
color: white;
|
|
||||||
border-color: #001c22;
|
|
||||||
background-color: #005b6e; }
|
|
||||||
.btn-primary:hover {
|
|
||||||
color: white;
|
|
||||||
border-color: #005264;
|
|
||||||
background-color: #005b6e; }
|
|
||||||
.btn-primary.active, .btn-primary:active,
|
|
||||||
.open > .btn-primary.dropdown-toggle {
|
|
||||||
color: white;
|
|
||||||
border-color: #005264;
|
|
||||||
background-color: #005b6e; }
|
|
||||||
.btn-primary.active.focus, .btn-primary.active:focus, .btn-primary.active:hover, .btn-primary:active.focus, .btn-primary:active:focus, .btn-primary:active:hover,
|
|
||||||
.open > .btn-primary.dropdown-toggle.focus,
|
|
||||||
.open > .btn-primary.dropdown-toggle:focus,
|
|
||||||
.open > .btn-primary.dropdown-toggle:hover {
|
|
||||||
color: white;
|
|
||||||
border-color: #001c22;
|
|
||||||
background-color: #003d4a; }
|
|
||||||
.btn-primary.active, .btn-primary:active,
|
|
||||||
.open > .btn-primary.dropdown-toggle {
|
|
||||||
background-image: none; }
|
|
||||||
.btn-primary.disabled.focus, .btn-primary.disabled:focus, .btn-primary.disabled:hover, .btn-primary[disabled].focus, .btn-primary[disabled]:focus, .btn-primary[disabled]:hover,
|
|
||||||
fieldset[disabled] .btn-primary.focus,
|
|
||||||
fieldset[disabled] .btn-primary:focus,
|
|
||||||
fieldset[disabled] .btn-primary:hover {
|
|
||||||
border-color: #0085A1;
|
|
||||||
background-color: #0085A1; }
|
|
||||||
.btn-primary .badge {
|
|
||||||
color: #0085A1;
|
|
||||||
background-color: white; }
|
|
||||||
|
|
||||||
.btn-lg {
|
|
||||||
font-size: 16px;
|
|
||||||
padding: 25px 35px; }
|
|
||||||
|
|
||||||
.btn-default:focus, .btn-default:hover {
|
|
||||||
color: white;
|
|
||||||
border: 1px solid #0085A1;
|
|
||||||
background-color: #0085A1; }
|
|
Binary file not shown.
Before Width: | Height: | Size: 32 KiB |
Binary file not shown.
Before Width: | Height: | Size: 283 KiB |
Binary file not shown.
Before Width: | Height: | Size: 169 KiB |
Binary file not shown.
Before Width: | Height: | Size: 138 KiB |
Binary file not shown.
Before Width: | Height: | Size: 112 KiB |
|
@ -1,41 +0,0 @@
|
||||||
(function($) {
|
|
||||||
"use strict"; // Start of use strict
|
|
||||||
|
|
||||||
// Floating label headings for the contact form
|
|
||||||
$("body").on("input propertychange", ".floating-label-form-group", function(e) {
|
|
||||||
$(this).toggleClass("floating-label-form-group-with-value", !!$(e.target).val());
|
|
||||||
}).on("focus", ".floating-label-form-group", function() {
|
|
||||||
$(this).addClass("floating-label-form-group-with-focus");
|
|
||||||
}).on("blur", ".floating-label-form-group", function() {
|
|
||||||
$(this).removeClass("floating-label-form-group-with-focus");
|
|
||||||
});
|
|
||||||
|
|
||||||
// Show the navbar when the page is scrolled up
|
|
||||||
var MQL = 1170;
|
|
||||||
|
|
||||||
//primary navigation slide-in effect
|
|
||||||
if ($(window).width() > MQL) {
|
|
||||||
var headerHeight = $('#mainNav').height();
|
|
||||||
$(window).on('scroll', {
|
|
||||||
previousTop: 0
|
|
||||||
},
|
|
||||||
function() {
|
|
||||||
var currentTop = $(window).scrollTop();
|
|
||||||
//check if user is scrolling up
|
|
||||||
if (currentTop < this.previousTop) {
|
|
||||||
//if scrolling up...
|
|
||||||
if (currentTop > 0 && $('#mainNav').hasClass('is-fixed')) {
|
|
||||||
$('#mainNav').addClass('is-visible');
|
|
||||||
} else {
|
|
||||||
$('#mainNav').removeClass('is-visible is-fixed');
|
|
||||||
}
|
|
||||||
} else if (currentTop > this.previousTop) {
|
|
||||||
//if scrolling down...
|
|
||||||
$('#mainNav').removeClass('is-visible');
|
|
||||||
if (currentTop > headerHeight && !$('#mainNav').hasClass('is-fixed')) $('#mainNav').addClass('is-fixed');
|
|
||||||
}
|
|
||||||
this.previousTop = currentTop;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
})(jQuery); // End of use strict
|
|
|
@ -1,75 +0,0 @@
|
||||||
$(function() {
|
|
||||||
|
|
||||||
$("#contactForm input,#contactForm textarea").jqBootstrapValidation({
|
|
||||||
preventSubmit: true,
|
|
||||||
submitError: function($form, event, errors) {
|
|
||||||
// additional error messages or events
|
|
||||||
},
|
|
||||||
submitSuccess: function($form, event) {
|
|
||||||
event.preventDefault(); // prevent default submit behaviour
|
|
||||||
// get values from FORM
|
|
||||||
var name = $("input#name").val();
|
|
||||||
var email = $("input#email").val();
|
|
||||||
var phone = $("input#phone").val();
|
|
||||||
var message = $("textarea#message").val();
|
|
||||||
var firstName = name; // For Success/Failure Message
|
|
||||||
// Check for white space in name for Success/Fail message
|
|
||||||
if (firstName.indexOf(' ') >= 0) {
|
|
||||||
firstName = name.split(' ').slice(0, -1).join(' ');
|
|
||||||
}
|
|
||||||
$this = $("#sendMessageButton");
|
|
||||||
$this.prop("disabled", true); // Disable submit button until AJAX call is complete to prevent duplicate messages
|
|
||||||
$.ajax({
|
|
||||||
url: "././mail/contact_me.php",
|
|
||||||
type: "POST",
|
|
||||||
data: {
|
|
||||||
name: name,
|
|
||||||
phone: phone,
|
|
||||||
email: email,
|
|
||||||
message: message
|
|
||||||
},
|
|
||||||
cache: false,
|
|
||||||
success: function() {
|
|
||||||
// Success message
|
|
||||||
$('#success').html("<div class='alert alert-success'>");
|
|
||||||
$('#success > .alert-success').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×")
|
|
||||||
.append("</button>");
|
|
||||||
$('#success > .alert-success')
|
|
||||||
.append("<strong>Your message has been sent. </strong>");
|
|
||||||
$('#success > .alert-success')
|
|
||||||
.append('</div>');
|
|
||||||
//clear all fields
|
|
||||||
$('#contactForm').trigger("reset");
|
|
||||||
},
|
|
||||||
error: function() {
|
|
||||||
// Fail message
|
|
||||||
$('#success').html("<div class='alert alert-danger'>");
|
|
||||||
$('#success > .alert-danger').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×")
|
|
||||||
.append("</button>");
|
|
||||||
$('#success > .alert-danger').append($("<strong>").text("Sorry " + firstName + ", it seems that my mail server is not responding. Please try again later!"));
|
|
||||||
$('#success > .alert-danger').append('</div>');
|
|
||||||
//clear all fields
|
|
||||||
$('#contactForm').trigger("reset");
|
|
||||||
},
|
|
||||||
complete: function() {
|
|
||||||
setTimeout(function() {
|
|
||||||
$this.prop("disabled", false); // Re-enable submit button when AJAX call is complete
|
|
||||||
}, 1000);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
filter: function() {
|
|
||||||
return $(this).is(":visible");
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
$("a[data-toggle=\"tab\"]").click(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
$(this).tab("show");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
/*When clicking on Full hide fail/success boxes */
|
|
||||||
$('#name').focus(function() {
|
|
||||||
$('#success').html('');
|
|
||||||
});
|
|
|
@ -1,937 +0,0 @@
|
||||||
/* jqBootstrapValidation
|
|
||||||
* A plugin for automating validation on Twitter Bootstrap formatted forms.
|
|
||||||
*
|
|
||||||
* v1.3.6
|
|
||||||
*
|
|
||||||
* License: MIT <http://opensource.org/licenses/mit-license.php> - see LICENSE file
|
|
||||||
*
|
|
||||||
* http://ReactiveRaven.github.com/jqBootstrapValidation/
|
|
||||||
*/
|
|
||||||
|
|
||||||
(function($) {
|
|
||||||
|
|
||||||
var createdElements = [];
|
|
||||||
|
|
||||||
var defaults = {
|
|
||||||
options: {
|
|
||||||
prependExistingHelpBlock: false,
|
|
||||||
sniffHtml: true, // sniff for 'required', 'maxlength', etc
|
|
||||||
preventSubmit: true, // stop the form submit event from firing if validation fails
|
|
||||||
submitError: false, // function called if there is an error when trying to submit
|
|
||||||
submitSuccess: false, // function called just before a successful submit event is sent to the server
|
|
||||||
semanticallyStrict: false, // set to true to tidy up generated HTML output
|
|
||||||
autoAdd: {
|
|
||||||
helpBlocks: true
|
|
||||||
},
|
|
||||||
filter: function() {
|
|
||||||
// return $(this).is(":visible"); // only validate elements you can see
|
|
||||||
return true; // validate everything
|
|
||||||
}
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
init: function(options) {
|
|
||||||
|
|
||||||
var settings = $.extend(true, {}, defaults);
|
|
||||||
|
|
||||||
settings.options = $.extend(true, settings.options, options);
|
|
||||||
|
|
||||||
var $siblingElements = this;
|
|
||||||
|
|
||||||
var uniqueForms = $.unique(
|
|
||||||
$siblingElements.map(function() {
|
|
||||||
return $(this).parents("form")[0];
|
|
||||||
}).toArray()
|
|
||||||
);
|
|
||||||
|
|
||||||
$(uniqueForms).bind("submit", function(e) {
|
|
||||||
var $form = $(this);
|
|
||||||
var warningsFound = 0;
|
|
||||||
var $inputs = $form.find("input,textarea,select").not("[type=submit],[type=image]").filter(settings.options.filter);
|
|
||||||
$inputs.trigger("submit.validation").trigger("validationLostFocus.validation");
|
|
||||||
|
|
||||||
$inputs.each(function(i, el) {
|
|
||||||
var $this = $(el),
|
|
||||||
$controlGroup = $this.parents(".form-group").first();
|
|
||||||
if (
|
|
||||||
$controlGroup.hasClass("warning")
|
|
||||||
) {
|
|
||||||
$controlGroup.removeClass("warning").addClass("error");
|
|
||||||
warningsFound++;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$inputs.trigger("validationLostFocus.validation");
|
|
||||||
|
|
||||||
if (warningsFound) {
|
|
||||||
if (settings.options.preventSubmit) {
|
|
||||||
e.preventDefault();
|
|
||||||
}
|
|
||||||
$form.addClass("error");
|
|
||||||
if ($.isFunction(settings.options.submitError)) {
|
|
||||||
settings.options.submitError($form, e, $inputs.jqBootstrapValidation("collectErrors", true));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$form.removeClass("error");
|
|
||||||
if ($.isFunction(settings.options.submitSuccess)) {
|
|
||||||
settings.options.submitSuccess($form, e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return this.each(function() {
|
|
||||||
|
|
||||||
// Get references to everything we're interested in
|
|
||||||
var $this = $(this),
|
|
||||||
$controlGroup = $this.parents(".form-group").first(),
|
|
||||||
$helpBlock = $controlGroup.find(".help-block").first(),
|
|
||||||
$form = $this.parents("form").first(),
|
|
||||||
validatorNames = [];
|
|
||||||
|
|
||||||
// create message container if not exists
|
|
||||||
if (!$helpBlock.length && settings.options.autoAdd && settings.options.autoAdd.helpBlocks) {
|
|
||||||
$helpBlock = $('<div class="help-block" />');
|
|
||||||
$controlGroup.find('.controls').append($helpBlock);
|
|
||||||
createdElements.push($helpBlock[0]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// SNIFF HTML FOR VALIDATORS
|
|
||||||
// =============================================================
|
|
||||||
|
|
||||||
// *snort sniff snuffle*
|
|
||||||
|
|
||||||
if (settings.options.sniffHtml) {
|
|
||||||
var message = "";
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// PATTERN
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("pattern") !== undefined) {
|
|
||||||
message = "Not in the expected format<!-- data-validation-pattern-message to override -->";
|
|
||||||
if ($this.data("validationPatternMessage")) {
|
|
||||||
message = $this.data("validationPatternMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationPatternMessage", message);
|
|
||||||
$this.data("validationPatternRegex", $this.attr("pattern"));
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// MAX
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("max") !== undefined || $this.attr("aria-valuemax") !== undefined) {
|
|
||||||
var max = ($this.attr("max") !== undefined ? $this.attr("max") : $this.attr("aria-valuemax"));
|
|
||||||
message = "Too high: Maximum of '" + max + "'<!-- data-validation-max-message to override -->";
|
|
||||||
if ($this.data("validationMaxMessage")) {
|
|
||||||
message = $this.data("validationMaxMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationMaxMessage", message);
|
|
||||||
$this.data("validationMaxMax", max);
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// MIN
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("min") !== undefined || $this.attr("aria-valuemin") !== undefined) {
|
|
||||||
var min = ($this.attr("min") !== undefined ? $this.attr("min") : $this.attr("aria-valuemin"));
|
|
||||||
message = "Too low: Minimum of '" + min + "'<!-- data-validation-min-message to override -->";
|
|
||||||
if ($this.data("validationMinMessage")) {
|
|
||||||
message = $this.data("validationMinMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationMinMessage", message);
|
|
||||||
$this.data("validationMinMin", min);
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// MAXLENGTH
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("maxlength") !== undefined) {
|
|
||||||
message = "Too long: Maximum of '" + $this.attr("maxlength") + "' characters<!-- data-validation-maxlength-message to override -->";
|
|
||||||
if ($this.data("validationMaxlengthMessage")) {
|
|
||||||
message = $this.data("validationMaxlengthMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationMaxlengthMessage", message);
|
|
||||||
$this.data("validationMaxlengthMaxlength", $this.attr("maxlength"));
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// MINLENGTH
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("minlength") !== undefined) {
|
|
||||||
message = "Too short: Minimum of '" + $this.attr("minlength") + "' characters<!-- data-validation-minlength-message to override -->";
|
|
||||||
if ($this.data("validationMinlengthMessage")) {
|
|
||||||
message = $this.data("validationMinlengthMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationMinlengthMessage", message);
|
|
||||||
$this.data("validationMinlengthMinlength", $this.attr("minlength"));
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// REQUIRED
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("required") !== undefined || $this.attr("aria-required") !== undefined) {
|
|
||||||
message = settings.builtInValidators.required.message;
|
|
||||||
if ($this.data("validationRequiredMessage")) {
|
|
||||||
message = $this.data("validationRequiredMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationRequiredMessage", message);
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// NUMBER
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("type") !== undefined && $this.attr("type").toLowerCase() === "number") {
|
|
||||||
message = settings.builtInValidators.number.message;
|
|
||||||
if ($this.data("validationNumberMessage")) {
|
|
||||||
message = $this.data("validationNumberMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationNumberMessage", message);
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// EMAIL
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("type") !== undefined && $this.attr("type").toLowerCase() === "email") {
|
|
||||||
message = "Not a valid email address<!-- data-validator-validemail-message to override -->";
|
|
||||||
if ($this.data("validationValidemailMessage")) {
|
|
||||||
message = $this.data("validationValidemailMessage");
|
|
||||||
} else if ($this.data("validationEmailMessage")) {
|
|
||||||
message = $this.data("validationEmailMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationValidemailMessage", message);
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// MINCHECKED
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("minchecked") !== undefined) {
|
|
||||||
message = "Not enough options checked; Minimum of '" + $this.attr("minchecked") + "' required<!-- data-validation-minchecked-message to override -->";
|
|
||||||
if ($this.data("validationMincheckedMessage")) {
|
|
||||||
message = $this.data("validationMincheckedMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationMincheckedMessage", message);
|
|
||||||
$this.data("validationMincheckedMinchecked", $this.attr("minchecked"));
|
|
||||||
}
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
// MAXCHECKED
|
|
||||||
// ---------------------------------------------------------
|
|
||||||
if ($this.attr("maxchecked") !== undefined) {
|
|
||||||
message = "Too many options checked; Maximum of '" + $this.attr("maxchecked") + "' required<!-- data-validation-maxchecked-message to override -->";
|
|
||||||
if ($this.data("validationMaxcheckedMessage")) {
|
|
||||||
message = $this.data("validationMaxcheckedMessage");
|
|
||||||
}
|
|
||||||
$this.data("validationMaxcheckedMessage", message);
|
|
||||||
$this.data("validationMaxcheckedMaxchecked", $this.attr("maxchecked"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// COLLECT VALIDATOR NAMES
|
|
||||||
// =============================================================
|
|
||||||
|
|
||||||
// Get named validators
|
|
||||||
if ($this.data("validation") !== undefined) {
|
|
||||||
validatorNames = $this.data("validation").split(",");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get extra ones defined on the element's data attributes
|
|
||||||
$.each($this.data(), function(i, el) {
|
|
||||||
var parts = i.replace(/([A-Z])/g, ",$1").split(",");
|
|
||||||
if (parts[0] === "validation" && parts[1]) {
|
|
||||||
validatorNames.push(parts[1]);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// NORMALISE VALIDATOR NAMES
|
|
||||||
// =============================================================
|
|
||||||
|
|
||||||
var validatorNamesToInspect = validatorNames;
|
|
||||||
var newValidatorNamesToInspect = [];
|
|
||||||
|
|
||||||
do // repeatedly expand 'shortcut' validators into their real validators
|
|
||||||
{
|
|
||||||
// Uppercase only the first letter of each name
|
|
||||||
$.each(validatorNames, function(i, el) {
|
|
||||||
validatorNames[i] = formatValidatorName(el);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Remove duplicate validator names
|
|
||||||
validatorNames = $.unique(validatorNames);
|
|
||||||
|
|
||||||
// Pull out the new validator names from each shortcut
|
|
||||||
newValidatorNamesToInspect = [];
|
|
||||||
$.each(validatorNamesToInspect, function(i, el) {
|
|
||||||
if ($this.data("validation" + el + "Shortcut") !== undefined) {
|
|
||||||
// Are these custom validators?
|
|
||||||
// Pull them out!
|
|
||||||
$.each($this.data("validation" + el + "Shortcut").split(","), function(i2, el2) {
|
|
||||||
newValidatorNamesToInspect.push(el2);
|
|
||||||
});
|
|
||||||
} else if (settings.builtInValidators[el.toLowerCase()]) {
|
|
||||||
// Is this a recognised built-in?
|
|
||||||
// Pull it out!
|
|
||||||
var validator = settings.builtInValidators[el.toLowerCase()];
|
|
||||||
if (validator.type.toLowerCase() === "shortcut") {
|
|
||||||
$.each(validator.shortcut.split(","), function(i, el) {
|
|
||||||
el = formatValidatorName(el);
|
|
||||||
newValidatorNamesToInspect.push(el);
|
|
||||||
validatorNames.push(el);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
validatorNamesToInspect = newValidatorNamesToInspect;
|
|
||||||
|
|
||||||
} while (validatorNamesToInspect.length > 0)
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// SET UP VALIDATOR ARRAYS
|
|
||||||
// =============================================================
|
|
||||||
|
|
||||||
var validators = {};
|
|
||||||
|
|
||||||
$.each(validatorNames, function(i, el) {
|
|
||||||
// Set up the 'override' message
|
|
||||||
var message = $this.data("validation" + el + "Message");
|
|
||||||
var hasOverrideMessage = (message !== undefined);
|
|
||||||
var foundValidator = false;
|
|
||||||
message =
|
|
||||||
(
|
|
||||||
message ?
|
|
||||||
message :
|
|
||||||
"'" + el + "' validation failed <!-- Add attribute 'data-validation-" + el.toLowerCase() + "-message' to input to change this message -->"
|
|
||||||
);
|
|
||||||
|
|
||||||
$.each(
|
|
||||||
settings.validatorTypes,
|
|
||||||
function(validatorType, validatorTemplate) {
|
|
||||||
if (validators[validatorType] === undefined) {
|
|
||||||
validators[validatorType] = [];
|
|
||||||
}
|
|
||||||
if (!foundValidator && $this.data("validation" + el + formatValidatorName(validatorTemplate.name)) !== undefined) {
|
|
||||||
validators[validatorType].push(
|
|
||||||
$.extend(
|
|
||||||
true, {
|
|
||||||
name: formatValidatorName(validatorTemplate.name),
|
|
||||||
message: message
|
|
||||||
},
|
|
||||||
validatorTemplate.init($this, el)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
foundValidator = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!foundValidator && settings.builtInValidators[el.toLowerCase()]) {
|
|
||||||
|
|
||||||
var validator = $.extend(true, {}, settings.builtInValidators[el.toLowerCase()]);
|
|
||||||
if (hasOverrideMessage) {
|
|
||||||
validator.message = message;
|
|
||||||
}
|
|
||||||
var validatorType = validator.type.toLowerCase();
|
|
||||||
|
|
||||||
if (validatorType === "shortcut") {
|
|
||||||
foundValidator = true;
|
|
||||||
} else {
|
|
||||||
$.each(
|
|
||||||
settings.validatorTypes,
|
|
||||||
function(validatorTemplateType, validatorTemplate) {
|
|
||||||
if (validators[validatorTemplateType] === undefined) {
|
|
||||||
validators[validatorTemplateType] = [];
|
|
||||||
}
|
|
||||||
if (!foundValidator && validatorType === validatorTemplateType.toLowerCase()) {
|
|
||||||
$this.data("validation" + el + formatValidatorName(validatorTemplate.name), validator[validatorTemplate.name.toLowerCase()]);
|
|
||||||
validators[validatorType].push(
|
|
||||||
$.extend(
|
|
||||||
validator,
|
|
||||||
validatorTemplate.init($this, el)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
foundValidator = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!foundValidator) {
|
|
||||||
$.error("Cannot find validation info for '" + el + "'");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// STORE FALLBACK VALUES
|
|
||||||
// =============================================================
|
|
||||||
|
|
||||||
$helpBlock.data(
|
|
||||||
"original-contents",
|
|
||||||
(
|
|
||||||
$helpBlock.data("original-contents") ?
|
|
||||||
$helpBlock.data("original-contents") :
|
|
||||||
$helpBlock.html()
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
$helpBlock.data(
|
|
||||||
"original-role",
|
|
||||||
(
|
|
||||||
$helpBlock.data("original-role") ?
|
|
||||||
$helpBlock.data("original-role") :
|
|
||||||
$helpBlock.attr("role")
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
$controlGroup.data(
|
|
||||||
"original-classes",
|
|
||||||
(
|
|
||||||
$controlGroup.data("original-clases") ?
|
|
||||||
$controlGroup.data("original-classes") :
|
|
||||||
$controlGroup.attr("class")
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
$this.data(
|
|
||||||
"original-aria-invalid",
|
|
||||||
(
|
|
||||||
$this.data("original-aria-invalid") ?
|
|
||||||
$this.data("original-aria-invalid") :
|
|
||||||
$this.attr("aria-invalid")
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// VALIDATION
|
|
||||||
// =============================================================
|
|
||||||
|
|
||||||
$this.bind(
|
|
||||||
"validation.validation",
|
|
||||||
function(event, params) {
|
|
||||||
|
|
||||||
var value = getValue($this);
|
|
||||||
|
|
||||||
// Get a list of the errors to apply
|
|
||||||
var errorsFound = [];
|
|
||||||
|
|
||||||
$.each(validators, function(validatorType, validatorTypeArray) {
|
|
||||||
if (value || value.length || (params && params.includeEmpty) || (!!settings.validatorTypes[validatorType].blockSubmit && params && !!params.submitting)) {
|
|
||||||
$.each(validatorTypeArray, function(i, validator) {
|
|
||||||
if (settings.validatorTypes[validatorType].validate($this, value, validator)) {
|
|
||||||
errorsFound.push(validator.message);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return errorsFound;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
$this.bind(
|
|
||||||
"getValidators.validation",
|
|
||||||
function() {
|
|
||||||
return validators;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
// =============================================================
|
|
||||||
// WATCH FOR CHANGES
|
|
||||||
// =============================================================
|
|
||||||
$this.bind(
|
|
||||||
"submit.validation",
|
|
||||||
function() {
|
|
||||||
return $this.triggerHandler("change.validation", {
|
|
||||||
submitting: true
|
|
||||||
});
|
|
||||||
}
|
|
||||||
);
|
|
||||||
$this.bind(
|
|
||||||
[
|
|
||||||
"keyup",
|
|
||||||
"focus",
|
|
||||||
"blur",
|
|
||||||
"click",
|
|
||||||
"keydown",
|
|
||||||
"keypress",
|
|
||||||
"change"
|
|
||||||
].join(".validation ") + ".validation",
|
|
||||||
function(e, params) {
|
|
||||||
|
|
||||||
var value = getValue($this);
|
|
||||||
|
|
||||||
var errorsFound = [];
|
|
||||||
|
|
||||||
$controlGroup.find("input,textarea,select").each(function(i, el) {
|
|
||||||
var oldCount = errorsFound.length;
|
|
||||||
$.each($(el).triggerHandler("validation.validation", params), function(j, message) {
|
|
||||||
errorsFound.push(message);
|
|
||||||
});
|
|
||||||
if (errorsFound.length > oldCount) {
|
|
||||||
$(el).attr("aria-invalid", "true");
|
|
||||||
} else {
|
|
||||||
var original = $this.data("original-aria-invalid");
|
|
||||||
$(el).attr("aria-invalid", (original !== undefined ? original : false));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$form.find("input,select,textarea").not($this).not("[name=\"" + $this.attr("name") + "\"]").trigger("validationLostFocus.validation");
|
|
||||||
|
|
||||||
errorsFound = $.unique(errorsFound.sort());
|
|
||||||
|
|
||||||
// Were there any errors?
|
|
||||||
if (errorsFound.length) {
|
|
||||||
// Better flag it up as a warning.
|
|
||||||
$controlGroup.removeClass("success error").addClass("warning");
|
|
||||||
|
|
||||||
// How many errors did we find?
|
|
||||||
if (settings.options.semanticallyStrict && errorsFound.length === 1) {
|
|
||||||
// Only one? Being strict? Just output it.
|
|
||||||
$helpBlock.html(errorsFound[0] +
|
|
||||||
(settings.options.prependExistingHelpBlock ? $helpBlock.data("original-contents") : ""));
|
|
||||||
} else {
|
|
||||||
// Multiple? Being sloppy? Glue them together into an UL.
|
|
||||||
$helpBlock.html("<ul role=\"alert\"><li>" + errorsFound.join("</li><li>") + "</li></ul>" +
|
|
||||||
(settings.options.prependExistingHelpBlock ? $helpBlock.data("original-contents") : ""));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$controlGroup.removeClass("warning error success");
|
|
||||||
if (value.length > 0) {
|
|
||||||
$controlGroup.addClass("success");
|
|
||||||
}
|
|
||||||
$helpBlock.html($helpBlock.data("original-contents"));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (e.type === "blur") {
|
|
||||||
$controlGroup.removeClass("success");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
$this.bind("validationLostFocus.validation", function() {
|
|
||||||
$controlGroup.removeClass("success");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
},
|
|
||||||
destroy: function() {
|
|
||||||
|
|
||||||
return this.each(
|
|
||||||
function() {
|
|
||||||
|
|
||||||
var
|
|
||||||
$this = $(this),
|
|
||||||
$controlGroup = $this.parents(".form-group").first(),
|
|
||||||
$helpBlock = $controlGroup.find(".help-block").first();
|
|
||||||
|
|
||||||
// remove our events
|
|
||||||
$this.unbind('.validation'); // events are namespaced.
|
|
||||||
// reset help text
|
|
||||||
$helpBlock.html($helpBlock.data("original-contents"));
|
|
||||||
// reset classes
|
|
||||||
$controlGroup.attr("class", $controlGroup.data("original-classes"));
|
|
||||||
// reset aria
|
|
||||||
$this.attr("aria-invalid", $this.data("original-aria-invalid"));
|
|
||||||
// reset role
|
|
||||||
$helpBlock.attr("role", $this.data("original-role"));
|
|
||||||
// remove all elements we created
|
|
||||||
if (createdElements.indexOf($helpBlock[0]) > -1) {
|
|
||||||
$helpBlock.remove();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
},
|
|
||||||
collectErrors: function(includeEmpty) {
|
|
||||||
|
|
||||||
var errorMessages = {};
|
|
||||||
this.each(function(i, el) {
|
|
||||||
var $el = $(el);
|
|
||||||
var name = $el.attr("name");
|
|
||||||
var errors = $el.triggerHandler("validation.validation", {
|
|
||||||
includeEmpty: true
|
|
||||||
});
|
|
||||||
errorMessages[name] = $.extend(true, errors, errorMessages[name]);
|
|
||||||
});
|
|
||||||
|
|
||||||
$.each(errorMessages, function(i, el) {
|
|
||||||
if (el.length === 0) {
|
|
||||||
delete errorMessages[i];
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return errorMessages;
|
|
||||||
|
|
||||||
},
|
|
||||||
hasErrors: function() {
|
|
||||||
|
|
||||||
var errorMessages = [];
|
|
||||||
|
|
||||||
this.each(function(i, el) {
|
|
||||||
errorMessages = errorMessages.concat(
|
|
||||||
$(el).triggerHandler("getValidators.validation") ? $(el).triggerHandler("validation.validation", {
|
|
||||||
submitting: true
|
|
||||||
}) : []
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
return (errorMessages.length > 0);
|
|
||||||
},
|
|
||||||
override: function(newDefaults) {
|
|
||||||
defaults = $.extend(true, defaults, newDefaults);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
validatorTypes: {
|
|
||||||
callback: {
|
|
||||||
name: "callback",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
validatorName: name,
|
|
||||||
callback: $this.data("validation" + name + "Callback"),
|
|
||||||
lastValue: $this.val(),
|
|
||||||
lastValid: true,
|
|
||||||
lastFinished: true
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
if (validator.lastValue === value && validator.lastFinished) {
|
|
||||||
return !validator.lastValid;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (validator.lastFinished === true) {
|
|
||||||
validator.lastValue = value;
|
|
||||||
validator.lastValid = true;
|
|
||||||
validator.lastFinished = false;
|
|
||||||
|
|
||||||
var rrjqbvValidator = validator;
|
|
||||||
var rrjqbvThis = $this;
|
|
||||||
executeFunctionByName(
|
|
||||||
validator.callback,
|
|
||||||
window,
|
|
||||||
$this,
|
|
||||||
value,
|
|
||||||
function(data) {
|
|
||||||
if (rrjqbvValidator.lastValue === data.value) {
|
|
||||||
rrjqbvValidator.lastValid = data.valid;
|
|
||||||
if (data.message) {
|
|
||||||
rrjqbvValidator.message = data.message;
|
|
||||||
}
|
|
||||||
rrjqbvValidator.lastFinished = true;
|
|
||||||
rrjqbvThis.data("validation" + rrjqbvValidator.validatorName + "Message", rrjqbvValidator.message);
|
|
||||||
// Timeout is set to avoid problems with the events being considered 'already fired'
|
|
||||||
setTimeout(function() {
|
|
||||||
rrjqbvThis.trigger("change.validation");
|
|
||||||
}, 1); // doesn't need a long timeout, just long enough for the event bubble to burst
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
|
|
||||||
}
|
|
||||||
},
|
|
||||||
ajax: {
|
|
||||||
name: "ajax",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
validatorName: name,
|
|
||||||
url: $this.data("validation" + name + "Ajax"),
|
|
||||||
lastValue: $this.val(),
|
|
||||||
lastValid: true,
|
|
||||||
lastFinished: true
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
if ("" + validator.lastValue === "" + value && validator.lastFinished === true) {
|
|
||||||
return validator.lastValid === false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (validator.lastFinished === true) {
|
|
||||||
validator.lastValue = value;
|
|
||||||
validator.lastValid = true;
|
|
||||||
validator.lastFinished = false;
|
|
||||||
$.ajax({
|
|
||||||
url: validator.url,
|
|
||||||
data: "value=" + value + "&field=" + $this.attr("name"),
|
|
||||||
dataType: "json",
|
|
||||||
success: function(data) {
|
|
||||||
if ("" + validator.lastValue === "" + data.value) {
|
|
||||||
validator.lastValid = !!(data.valid);
|
|
||||||
if (data.message) {
|
|
||||||
validator.message = data.message;
|
|
||||||
}
|
|
||||||
validator.lastFinished = true;
|
|
||||||
$this.data("validation" + validator.validatorName + "Message", validator.message);
|
|
||||||
// Timeout is set to avoid problems with the events being considered 'already fired'
|
|
||||||
setTimeout(function() {
|
|
||||||
$this.trigger("change.validation");
|
|
||||||
}, 1); // doesn't need a long timeout, just long enough for the event bubble to burst
|
|
||||||
}
|
|
||||||
},
|
|
||||||
failure: function() {
|
|
||||||
validator.lastValid = true;
|
|
||||||
validator.message = "ajax call failed";
|
|
||||||
validator.lastFinished = true;
|
|
||||||
$this.data("validation" + validator.validatorName + "Message", validator.message);
|
|
||||||
// Timeout is set to avoid problems with the events being considered 'already fired'
|
|
||||||
setTimeout(function() {
|
|
||||||
$this.trigger("change.validation");
|
|
||||||
}, 1); // doesn't need a long timeout, just long enough for the event bubble to burst
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
|
|
||||||
}
|
|
||||||
},
|
|
||||||
regex: {
|
|
||||||
name: "regex",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
regex: regexFromString($this.data("validation" + name + "Regex"))
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return (!validator.regex.test(value) && !validator.negative) ||
|
|
||||||
(validator.regex.test(value) && validator.negative);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
required: {
|
|
||||||
name: "required",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return !!(value.length === 0 && !validator.negative) ||
|
|
||||||
!!(value.length > 0 && validator.negative);
|
|
||||||
},
|
|
||||||
blockSubmit: true
|
|
||||||
},
|
|
||||||
match: {
|
|
||||||
name: "match",
|
|
||||||
init: function($this, name) {
|
|
||||||
var element = $this.parents("form").first().find("[name=\"" + $this.data("validation" + name + "Match") + "\"]").first();
|
|
||||||
element.bind("validation.validation", function() {
|
|
||||||
$this.trigger("change.validation", {
|
|
||||||
submitting: true
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
"element": element
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return (value !== validator.element.val() && !validator.negative) ||
|
|
||||||
(value === validator.element.val() && validator.negative);
|
|
||||||
},
|
|
||||||
blockSubmit: true
|
|
||||||
},
|
|
||||||
max: {
|
|
||||||
name: "max",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
max: $this.data("validation" + name + "Max")
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return (parseFloat(value, 10) > parseFloat(validator.max, 10) && !validator.negative) ||
|
|
||||||
(parseFloat(value, 10) <= parseFloat(validator.max, 10) && validator.negative);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
min: {
|
|
||||||
name: "min",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
min: $this.data("validation" + name + "Min")
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return (parseFloat(value) < parseFloat(validator.min) && !validator.negative) ||
|
|
||||||
(parseFloat(value) >= parseFloat(validator.min) && validator.negative);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
maxlength: {
|
|
||||||
name: "maxlength",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
maxlength: $this.data("validation" + name + "Maxlength")
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return ((value.length > validator.maxlength) && !validator.negative) ||
|
|
||||||
((value.length <= validator.maxlength) && validator.negative);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
minlength: {
|
|
||||||
name: "minlength",
|
|
||||||
init: function($this, name) {
|
|
||||||
return {
|
|
||||||
minlength: $this.data("validation" + name + "Minlength")
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return ((value.length < validator.minlength) && !validator.negative) ||
|
|
||||||
((value.length >= validator.minlength) && validator.negative);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
maxchecked: {
|
|
||||||
name: "maxchecked",
|
|
||||||
init: function($this, name) {
|
|
||||||
var elements = $this.parents("form").first().find("[name=\"" + $this.attr("name") + "\"]");
|
|
||||||
elements.bind("click.validation", function() {
|
|
||||||
$this.trigger("change.validation", {
|
|
||||||
includeEmpty: true
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
maxchecked: $this.data("validation" + name + "Maxchecked"),
|
|
||||||
elements: elements
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return (validator.elements.filter(":checked").length > validator.maxchecked && !validator.negative) ||
|
|
||||||
(validator.elements.filter(":checked").length <= validator.maxchecked && validator.negative);
|
|
||||||
},
|
|
||||||
blockSubmit: true
|
|
||||||
},
|
|
||||||
minchecked: {
|
|
||||||
name: "minchecked",
|
|
||||||
init: function($this, name) {
|
|
||||||
var elements = $this.parents("form").first().find("[name=\"" + $this.attr("name") + "\"]");
|
|
||||||
elements.bind("click.validation", function() {
|
|
||||||
$this.trigger("change.validation", {
|
|
||||||
includeEmpty: true
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
minchecked: $this.data("validation" + name + "Minchecked"),
|
|
||||||
elements: elements
|
|
||||||
};
|
|
||||||
},
|
|
||||||
validate: function($this, value, validator) {
|
|
||||||
return (validator.elements.filter(":checked").length < validator.minchecked && !validator.negative) ||
|
|
||||||
(validator.elements.filter(":checked").length >= validator.minchecked && validator.negative);
|
|
||||||
},
|
|
||||||
blockSubmit: true
|
|
||||||
}
|
|
||||||
},
|
|
||||||
builtInValidators: {
|
|
||||||
email: {
|
|
||||||
name: "Email",
|
|
||||||
type: "shortcut",
|
|
||||||
shortcut: "validemail"
|
|
||||||
},
|
|
||||||
validemail: {
|
|
||||||
name: "Validemail",
|
|
||||||
type: "regex",
|
|
||||||
regex: "[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\\.[A-Za-z]{2,4}",
|
|
||||||
message: "Not a valid email address<!-- data-validator-validemail-message to override -->"
|
|
||||||
},
|
|
||||||
passwordagain: {
|
|
||||||
name: "Passwordagain",
|
|
||||||
type: "match",
|
|
||||||
match: "password",
|
|
||||||
message: "Does not match the given password<!-- data-validator-paswordagain-message to override -->"
|
|
||||||
},
|
|
||||||
positive: {
|
|
||||||
name: "Positive",
|
|
||||||
type: "shortcut",
|
|
||||||
shortcut: "number,positivenumber"
|
|
||||||
},
|
|
||||||
negative: {
|
|
||||||
name: "Negative",
|
|
||||||
type: "shortcut",
|
|
||||||
shortcut: "number,negativenumber"
|
|
||||||
},
|
|
||||||
number: {
|
|
||||||
name: "Number",
|
|
||||||
type: "regex",
|
|
||||||
regex: "([+-]?\\\d+(\\\.\\\d*)?([eE][+-]?[0-9]+)?)?",
|
|
||||||
message: "Must be a number<!-- data-validator-number-message to override -->"
|
|
||||||
},
|
|
||||||
integer: {
|
|
||||||
name: "Integer",
|
|
||||||
type: "regex",
|
|
||||||
regex: "[+-]?\\\d+",
|
|
||||||
message: "No decimal places allowed<!-- data-validator-integer-message to override -->"
|
|
||||||
},
|
|
||||||
positivenumber: {
|
|
||||||
name: "Positivenumber",
|
|
||||||
type: "min",
|
|
||||||
min: 0,
|
|
||||||
message: "Must be a positive number<!-- data-validator-positivenumber-message to override -->"
|
|
||||||
},
|
|
||||||
negativenumber: {
|
|
||||||
name: "Negativenumber",
|
|
||||||
type: "max",
|
|
||||||
max: 0,
|
|
||||||
message: "Must be a negative number<!-- data-validator-negativenumber-message to override -->"
|
|
||||||
},
|
|
||||||
required: {
|
|
||||||
name: "Required",
|
|
||||||
type: "required",
|
|
||||||
message: "This is required<!-- data-validator-required-message to override -->"
|
|
||||||
},
|
|
||||||
checkone: {
|
|
||||||
name: "Checkone",
|
|
||||||
type: "minchecked",
|
|
||||||
minchecked: 1,
|
|
||||||
message: "Check at least one option<!-- data-validation-checkone-message to override -->"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var formatValidatorName = function(name) {
|
|
||||||
return name
|
|
||||||
.toLowerCase()
|
|
||||||
.replace(
|
|
||||||
/(^|\s)([a-z])/g,
|
|
||||||
function(m, p1, p2) {
|
|
||||||
return p1 + p2.toUpperCase();
|
|
||||||
}
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
var getValue = function($this) {
|
|
||||||
// Extract the value we're talking about
|
|
||||||
var value = $this.val();
|
|
||||||
var type = $this.attr("type");
|
|
||||||
if (type === "checkbox") {
|
|
||||||
value = ($this.is(":checked") ? value : "");
|
|
||||||
}
|
|
||||||
if (type === "radio") {
|
|
||||||
value = ($('input[name="' + $this.attr("name") + '"]:checked').length > 0 ? value : "");
|
|
||||||
}
|
|
||||||
return value;
|
|
||||||
};
|
|
||||||
|
|
||||||
function regexFromString(inputstring) {
|
|
||||||
return new RegExp("^" + inputstring + "$");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Thanks to Jason Bunting via StackOverflow.com
|
|
||||||
*
|
|
||||||
* http://stackoverflow.com/questions/359788/how-to-execute-a-javascript-function-when-i-have-its-name-as-a-string#answer-359910
|
|
||||||
* Short link: http://tinyurl.com/executeFunctionByName
|
|
||||||
**/
|
|
||||||
function executeFunctionByName(functionName, context /*, args*/ ) {
|
|
||||||
var args = Array.prototype.slice.call(arguments).splice(2);
|
|
||||||
var namespaces = functionName.split(".");
|
|
||||||
var func = namespaces.pop();
|
|
||||||
for (var i = 0; i < namespaces.length; i++) {
|
|
||||||
context = context[namespaces[i]];
|
|
||||||
}
|
|
||||||
return context[func].apply(this, args);
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.jqBootstrapValidation = function(method) {
|
|
||||||
|
|
||||||
if (defaults.methods[method]) {
|
|
||||||
return defaults.methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
|
|
||||||
} else if (typeof method === 'object' || !method) {
|
|
||||||
return defaults.methods.init.apply(this, arguments);
|
|
||||||
} else {
|
|
||||||
$.error('Method ' + method + ' does not exist on jQuery.jqBootstrapValidation');
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
$.jqBootstrapValidation = function(options) {
|
|
||||||
$(":input").not("[type=image],[type=submit]").jqBootstrapValidation.apply(this, arguments);
|
|
||||||
};
|
|
||||||
|
|
||||||
})(jQuery);
|
|
|
@ -2,7 +2,7 @@
|
||||||
"theme-data":
|
"theme-data":
|
||||||
{
|
{
|
||||||
"name": "Clean Blog",
|
"name": "Clean Blog",
|
||||||
"description": "Clean blog is a carefully styled Bootstrap blog theme that is perfect for personal or company blogs. This theme features four HTML pages including a blog index, an about page, a sample post, and a contact page."
|
"description": "Clean blog is a carefully styled Bootstrap blog theme that is perfect for personal or company blogs."
|
||||||
},
|
},
|
||||||
"posted-by": "Posted by"
|
"posted-by": "Posted by"
|
||||||
}
|
}
|
|
@ -1,26 +0,0 @@
|
||||||
<?php
|
|
||||||
// Check for empty fields
|
|
||||||
if(empty($_POST['name']) ||
|
|
||||||
empty($_POST['email']) ||
|
|
||||||
empty($_POST['phone']) ||
|
|
||||||
empty($_POST['message']) ||
|
|
||||||
!filter_var($_POST['email'],FILTER_VALIDATE_EMAIL))
|
|
||||||
{
|
|
||||||
echo "No arguments Provided!";
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$name = strip_tags(htmlspecialchars($_POST['name']));
|
|
||||||
$email_address = strip_tags(htmlspecialchars($_POST['email']));
|
|
||||||
$phone = strip_tags(htmlspecialchars($_POST['phone']));
|
|
||||||
$message = strip_tags(htmlspecialchars($_POST['message']));
|
|
||||||
|
|
||||||
// Create the email and send the message
|
|
||||||
$to = 'yourname@yourdomain.com'; // Add your email address inbetween the '' replacing yourname@yourdomain.com - This is where the form will send a message to.
|
|
||||||
$email_subject = "Website Contact Form: $name";
|
|
||||||
$email_body = "You have received a new message from your website contact form.\n\n"."Here are the details:\n\nName: $name\n\nEmail: $email_address\n\nPhone: $phone\n\nMessage:\n$message";
|
|
||||||
$headers = "From: noreply@yourdomain.com\n"; // This is the email address the generated message will be from. We recommend using something like noreply@yourdomain.com.
|
|
||||||
$headers .= "Reply-To: $email_address";
|
|
||||||
mail($to,$email_subject,$email_body,$headers);
|
|
||||||
return true;
|
|
||||||
?>
|
|
|
@ -12,6 +12,7 @@
|
||||||
// CSS
|
// CSS
|
||||||
echo Theme::css('vendor/bootstrap/css/bootstrap.min.css');
|
echo Theme::css('vendor/bootstrap/css/bootstrap.min.css');
|
||||||
echo Theme::css('css/clean-blog.min.css');
|
echo Theme::css('css/clean-blog.min.css');
|
||||||
|
echo Theme::css('css/bludit.css');
|
||||||
|
|
||||||
// FontAwesome from Bludit Core
|
// FontAwesome from Bludit Core
|
||||||
echo Theme::fontAwesome();
|
echo Theme::fontAwesome();
|
||||||
|
|
|
@ -1,28 +0,0 @@
|
||||||
// Bootstrap overrides for this template
|
|
||||||
.btn {
|
|
||||||
font-size: 14px;
|
|
||||||
font-weight: 800;
|
|
||||||
padding: 15px 25px;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
text-transform: uppercase;
|
|
||||||
border-radius: 0;
|
|
||||||
@include sans-serif-font;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-primary {
|
|
||||||
@include button-variant(white, $theme-primary, $theme-primary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-lg {
|
|
||||||
font-size: 16px;
|
|
||||||
padding: 25px 35px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-default {
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: white;
|
|
||||||
border: 1px solid $theme-primary;
|
|
||||||
background-color: $theme-primary;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,60 +0,0 @@
|
||||||
// Styling for the contact page
|
|
||||||
.floating-label-form-group {
|
|
||||||
font-size: 14px;
|
|
||||||
position: relative;
|
|
||||||
margin-bottom: 0;
|
|
||||||
padding-bottom: 0.5em;
|
|
||||||
border-bottom: 1px solid $gray-lighter;
|
|
||||||
input,
|
|
||||||
textarea {
|
|
||||||
font-size: 1.5em;
|
|
||||||
position: relative;
|
|
||||||
z-index: 1;
|
|
||||||
padding: 0;
|
|
||||||
resize: none;
|
|
||||||
border: none;
|
|
||||||
border-radius: 0;
|
|
||||||
background: none;
|
|
||||||
box-shadow: none !important;
|
|
||||||
@include serif-font;
|
|
||||||
&::-webkit-input-placeholder {
|
|
||||||
color: $gray-light;
|
|
||||||
@include serif-font;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
label {
|
|
||||||
font-size: 0.85em;
|
|
||||||
line-height: 1.764705882em;
|
|
||||||
position: relative;
|
|
||||||
z-index: 0;
|
|
||||||
top: 2em;
|
|
||||||
display: block;
|
|
||||||
margin: 0;
|
|
||||||
-webkit-transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
-moz-transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
-ms-transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
transition: top 0.3s ease, opacity 0.3s ease;
|
|
||||||
vertical-align: middle;
|
|
||||||
vertical-align: baseline;
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
.help-block {
|
|
||||||
margin: 15px 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.floating-label-form-group-with-value {
|
|
||||||
label {
|
|
||||||
top: 0;
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.floating-label-form-group-with-focus {
|
|
||||||
label {
|
|
||||||
color: $theme-primary;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
form .form-group:first-child .floating-label-form-group {
|
|
||||||
border-top: 1px solid $gray-lighter;
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
// Styling for the footer
|
|
||||||
footer {
|
|
||||||
padding: 50px 0 65px;
|
|
||||||
.list-inline {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
.copyright {
|
|
||||||
font-size: 14px;
|
|
||||||
margin-bottom: 0;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,88 +0,0 @@
|
||||||
// Global styling for this template
|
|
||||||
body {
|
|
||||||
font-size: 20px;
|
|
||||||
color: $gray-dark;
|
|
||||||
@include serif-font;
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
line-height: 1.5;
|
|
||||||
margin: 30px 0;
|
|
||||||
a {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3,
|
|
||||||
h4,
|
|
||||||
h5,
|
|
||||||
h6 {
|
|
||||||
font-weight: 800;
|
|
||||||
@include sans-serif-font;
|
|
||||||
}
|
|
||||||
|
|
||||||
a {
|
|
||||||
color: $gray-dark;
|
|
||||||
@include transition-all;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: $theme-primary;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
a img {
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
cursor: zoom-in;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
blockquote {
|
|
||||||
font-style: italic;
|
|
||||||
color: $gray-light;
|
|
||||||
}
|
|
||||||
|
|
||||||
.section-heading {
|
|
||||||
font-size: 36px;
|
|
||||||
font-weight: 700;
|
|
||||||
margin-top: 60px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.caption {
|
|
||||||
font-size: 14px;
|
|
||||||
font-style: italic;
|
|
||||||
display: block;
|
|
||||||
margin: 0;
|
|
||||||
padding: 10px;
|
|
||||||
text-align: center;
|
|
||||||
border-bottom-right-radius: 5px;
|
|
||||||
border-bottom-left-radius: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-moz-selection {
|
|
||||||
color: white;
|
|
||||||
background: $theme-primary;
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
::selection {
|
|
||||||
color: white;
|
|
||||||
background: $theme-primary;
|
|
||||||
text-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
img::selection {
|
|
||||||
color: white;
|
|
||||||
background: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
img::-moz-selection {
|
|
||||||
color: white;
|
|
||||||
background: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
-webkit-tap-highlight-color: $theme-primary;
|
|
||||||
}
|
|
|
@ -1,72 +0,0 @@
|
||||||
// Styling for the masthead
|
|
||||||
header.masthead {
|
|
||||||
// NOTE: Background images are set within the HTML using inline CSS!
|
|
||||||
margin-bottom: 50px;
|
|
||||||
background: no-repeat center center;
|
|
||||||
background-color: $gray-light;
|
|
||||||
background-attachment: scroll;
|
|
||||||
@include background-cover;
|
|
||||||
.page-heading,
|
|
||||||
.post-heading,
|
|
||||||
.site-heading {
|
|
||||||
padding: 200px 0 150px;
|
|
||||||
color: white;
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
padding: 200px 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.page-heading,
|
|
||||||
.site-heading {
|
|
||||||
text-align: center;
|
|
||||||
h1 {
|
|
||||||
font-size: 50px;
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
||||||
.subheading {
|
|
||||||
font-size: 24px;
|
|
||||||
font-weight: 300;
|
|
||||||
line-height: 1.1;
|
|
||||||
display: block;
|
|
||||||
margin: 10px 0 0;
|
|
||||||
@include sans-serif-font;
|
|
||||||
}
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
h1 {
|
|
||||||
font-size: 80px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.post-heading {
|
|
||||||
h1 {
|
|
||||||
font-size: 35px;
|
|
||||||
}
|
|
||||||
.meta,
|
|
||||||
.subheading {
|
|
||||||
line-height: 1.1;
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
.subheading {
|
|
||||||
font-size: 24px;
|
|
||||||
font-weight: 600;
|
|
||||||
margin: 10px 0 30px;
|
|
||||||
@include sans-serif-font;
|
|
||||||
}
|
|
||||||
.meta {
|
|
||||||
font-size: 20px;
|
|
||||||
font-weight: 300;
|
|
||||||
font-style: italic;
|
|
||||||
@include serif-font;
|
|
||||||
a {
|
|
||||||
color: white;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
h1 {
|
|
||||||
font-size: 55px;
|
|
||||||
}
|
|
||||||
.subheading {
|
|
||||||
font-size: 30px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,68 +0,0 @@
|
||||||
// Mixins
|
|
||||||
// Bootstrap Button Variant
|
|
||||||
@mixin button-variant($color, $background, $border) {
|
|
||||||
color: $color;
|
|
||||||
border-color: $border;
|
|
||||||
background-color: $background;
|
|
||||||
&.focus,
|
|
||||||
&:focus {
|
|
||||||
color: $color;
|
|
||||||
border-color: darken($border, 25%);
|
|
||||||
background-color: darken($background, 10%);
|
|
||||||
}
|
|
||||||
&:hover {
|
|
||||||
color: $color;
|
|
||||||
border-color: darken($border, 12%);
|
|
||||||
background-color: darken($background, 10%);
|
|
||||||
}
|
|
||||||
&.active,
|
|
||||||
&:active,
|
|
||||||
.open > &.dropdown-toggle {
|
|
||||||
color: $color;
|
|
||||||
border-color: darken($border, 12%);
|
|
||||||
background-color: darken($background, 10%);
|
|
||||||
&.focus,
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: $color;
|
|
||||||
border-color: darken($border, 25%);
|
|
||||||
background-color: darken($background, 17%);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
&.active,
|
|
||||||
&:active,
|
|
||||||
.open > &.dropdown-toggle {
|
|
||||||
background-image: none;
|
|
||||||
}
|
|
||||||
&.disabled,
|
|
||||||
&[disabled],
|
|
||||||
fieldset[disabled] & {
|
|
||||||
&.focus,
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
border-color: $border;
|
|
||||||
background-color: $background;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.badge {
|
|
||||||
color: $background;
|
|
||||||
background-color: $color;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@mixin transition-all() {
|
|
||||||
-webkit-transition: all 0.2s;
|
|
||||||
-moz-transition: all 0.2s;
|
|
||||||
transition: all 0.2s;
|
|
||||||
}
|
|
||||||
@mixin background-cover() {
|
|
||||||
-webkit-background-size: cover;
|
|
||||||
-moz-background-size: cover;
|
|
||||||
-o-background-size: cover;
|
|
||||||
background-size: cover;
|
|
||||||
}
|
|
||||||
@mixin serif-font() {
|
|
||||||
font-family: 'Lora', 'Times New Roman', serif;
|
|
||||||
}
|
|
||||||
@mixin sans-serif-font() {
|
|
||||||
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
|
||||||
}
|
|
|
@ -1,100 +0,0 @@
|
||||||
// Styling for the navbar
|
|
||||||
#mainNav {
|
|
||||||
position: absolute;
|
|
||||||
border-bottom: 1px solid $gray-lighter;
|
|
||||||
background-color: white;
|
|
||||||
@include sans-serif-font;
|
|
||||||
.navbar-brand {
|
|
||||||
font-weight: 800;
|
|
||||||
color: $gray-light;
|
|
||||||
}
|
|
||||||
.navbar-toggler {
|
|
||||||
font-size: 12px;
|
|
||||||
font-weight: 800;
|
|
||||||
padding: 13px;
|
|
||||||
text-transform: uppercase;
|
|
||||||
color: $gray-light;
|
|
||||||
}
|
|
||||||
.navbar-nav {
|
|
||||||
> li.nav-item {
|
|
||||||
> a {
|
|
||||||
font-size: 12px;
|
|
||||||
font-weight: 800;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media only screen and (min-width: 992px) {
|
|
||||||
border-bottom: 1px solid transparent;
|
|
||||||
background: transparent;
|
|
||||||
.navbar-brand {
|
|
||||||
padding: 15px 20px;
|
|
||||||
color: white;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: fade-out(white, .2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.navbar-nav {
|
|
||||||
> li.nav-item {
|
|
||||||
> a {
|
|
||||||
padding: 15px 20px;
|
|
||||||
color: white;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: fade-out(white, .2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media only screen and (min-width: 1170px) {
|
|
||||||
-webkit-transition: background-color 0.2s;
|
|
||||||
-moz-transition: background-color 0.2s;
|
|
||||||
transition: background-color 0.2s;
|
|
||||||
/* Force Hardware Acceleration in WebKit */
|
|
||||||
-webkit-transform: translate3d(0, 0, 0);
|
|
||||||
-moz-transform: translate3d(0, 0, 0);
|
|
||||||
-ms-transform: translate3d(0, 0, 0);
|
|
||||||
-o-transform: translate3d(0, 0, 0);
|
|
||||||
transform: translate3d(0, 0, 0);
|
|
||||||
-webkit-backface-visibility: hidden;
|
|
||||||
&.is-fixed {
|
|
||||||
/* when the user scrolls down, we hide the header right above the viewport */
|
|
||||||
position: fixed;
|
|
||||||
top: -77px;
|
|
||||||
-webkit-transition: -webkit-transform 0.2s;
|
|
||||||
-moz-transition: -moz-transform 0.2s;
|
|
||||||
transition: transform 0.2s;
|
|
||||||
border-bottom: 1px solid darken(white, .05);
|
|
||||||
background-color: fade-out(white, .1);
|
|
||||||
.navbar-brand {
|
|
||||||
color: $gray-dark;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: $theme-primary;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.navbar-nav {
|
|
||||||
> li.nav-item {
|
|
||||||
> a {
|
|
||||||
color: $gray-dark;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
color: $theme-primary;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
&.is-visible {
|
|
||||||
/* if the user changes the scrolling direction, we show the header */
|
|
||||||
-webkit-transform: translate3d(0, 100%, 0);
|
|
||||||
-moz-transform: translate3d(0, 100%, 0);
|
|
||||||
-ms-transform: translate3d(0, 100%, 0);
|
|
||||||
-o-transform: translate3d(0, 100%, 0);
|
|
||||||
transform: translate3d(0, 100%, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
// Styling for the post page
|
|
||||||
.post-preview {
|
|
||||||
> a {
|
|
||||||
color: $gray-dark;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
text-decoration: none;
|
|
||||||
color: $theme-primary;
|
|
||||||
}
|
|
||||||
> .post-title {
|
|
||||||
font-size: 30px;
|
|
||||||
margin-top: 30px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
> .post-subtitle {
|
|
||||||
font-weight: 300;
|
|
||||||
margin: 0 0 10px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
> .post-meta {
|
|
||||||
font-size: 18px;
|
|
||||||
font-style: italic;
|
|
||||||
margin-top: 0;
|
|
||||||
color: $gray-light;
|
|
||||||
> a {
|
|
||||||
text-decoration: none;
|
|
||||||
color: $gray-dark;
|
|
||||||
&:focus,
|
|
||||||
&:hover {
|
|
||||||
text-decoration: underline;
|
|
||||||
color: $theme-primary;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media only screen and (min-width: 768px) {
|
|
||||||
> a {
|
|
||||||
> .post-title {
|
|
||||||
font-size: 36px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
// Variables
|
|
||||||
|
|
||||||
// Gray and Brand Colors for use across theme
|
|
||||||
|
|
||||||
$theme-primary: #0085A1;
|
|
||||||
|
|
||||||
$gray-base: #000 !default;
|
|
||||||
$gray-darker: lighten($gray-base, 13.5%) !default;
|
|
||||||
$gray-dark: lighten($gray-base, 20%) !default;
|
|
||||||
$gray: lighten($gray-base, 33.5%) !default;
|
|
||||||
$gray-light: lighten($gray-base, 46.7%) !default;
|
|
||||||
$gray-lighter: lighten($gray-base, 93.5%) !default;
|
|
|
@ -1,9 +0,0 @@
|
||||||
@import "variables.scss";
|
|
||||||
@import "mixins.scss";
|
|
||||||
@import "global.scss";
|
|
||||||
@import "navbar.scss";
|
|
||||||
@import "masthead.scss";
|
|
||||||
@import "post.scss";
|
|
||||||
@import "contact.scss";
|
|
||||||
@import "footer.scss";
|
|
||||||
@import "bootstrap-overrides.scss";
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,330 +0,0 @@
|
||||||
html {
|
|
||||||
box-sizing: border-box;
|
|
||||||
font-family: sans-serif;
|
|
||||||
line-height: 1.15;
|
|
||||||
-webkit-text-size-adjust: 100%;
|
|
||||||
-ms-text-size-adjust: 100%;
|
|
||||||
-ms-overflow-style: scrollbar;
|
|
||||||
-webkit-tap-highlight-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
*,
|
|
||||||
*::before,
|
|
||||||
*::after {
|
|
||||||
box-sizing: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
@-ms-viewport {
|
|
||||||
width: device-width;
|
|
||||||
}
|
|
||||||
|
|
||||||
article, aside, dialog, figcaption, figure, footer, header, hgroup, main, nav, section {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
body {
|
|
||||||
margin: 0;
|
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
|
||||||
font-size: 1rem;
|
|
||||||
font-weight: normal;
|
|
||||||
line-height: 1.5;
|
|
||||||
color: #212529;
|
|
||||||
background-color: #fff;
|
|
||||||
}
|
|
||||||
|
|
||||||
[tabindex="-1"]:focus {
|
|
||||||
outline: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
hr {
|
|
||||||
box-sizing: content-box;
|
|
||||||
height: 0;
|
|
||||||
overflow: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1, h2, h3, h4, h5, h6 {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: .5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
abbr[title],
|
|
||||||
abbr[data-original-title] {
|
|
||||||
text-decoration: underline;
|
|
||||||
-webkit-text-decoration: underline dotted;
|
|
||||||
text-decoration: underline dotted;
|
|
||||||
cursor: help;
|
|
||||||
border-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
address {
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
font-style: normal;
|
|
||||||
line-height: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol,
|
|
||||||
ul,
|
|
||||||
dl {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
ol ol,
|
|
||||||
ul ul,
|
|
||||||
ol ul,
|
|
||||||
ul ol {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
dt {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
dd {
|
|
||||||
margin-bottom: .5rem;
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
blockquote {
|
|
||||||
margin: 0 0 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
dfn {
|
|
||||||
font-style: italic;
|
|
||||||
}
|
|
||||||
|
|
||||||
b,
|
|
||||||
strong {
|
|
||||||
font-weight: bolder;
|
|
||||||
}
|
|
||||||
|
|
||||||
small {
|
|
||||||
font-size: 80%;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub,
|
|
||||||
sup {
|
|
||||||
position: relative;
|
|
||||||
font-size: 75%;
|
|
||||||
line-height: 0;
|
|
||||||
vertical-align: baseline;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub {
|
|
||||||
bottom: -.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
sup {
|
|
||||||
top: -.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
a {
|
|
||||||
color: #007bff;
|
|
||||||
text-decoration: none;
|
|
||||||
background-color: transparent;
|
|
||||||
-webkit-text-decoration-skip: objects;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:hover {
|
|
||||||
color: #0056b3;
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:not([href]):not([tabindex]) {
|
|
||||||
color: inherit;
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {
|
|
||||||
color: inherit;
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
a:not([href]):not([tabindex]):focus {
|
|
||||||
outline: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
pre,
|
|
||||||
code,
|
|
||||||
kbd,
|
|
||||||
samp {
|
|
||||||
font-family: monospace, monospace;
|
|
||||||
font-size: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
pre {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
overflow: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
figure {
|
|
||||||
margin: 0 0 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
img {
|
|
||||||
vertical-align: middle;
|
|
||||||
border-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
svg:not(:root) {
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
a,
|
|
||||||
area,
|
|
||||||
button,
|
|
||||||
[role="button"],
|
|
||||||
input,
|
|
||||||
label,
|
|
||||||
select,
|
|
||||||
summary,
|
|
||||||
textarea {
|
|
||||||
-ms-touch-action: manipulation;
|
|
||||||
touch-action: manipulation;
|
|
||||||
}
|
|
||||||
|
|
||||||
table {
|
|
||||||
border-collapse: collapse;
|
|
||||||
}
|
|
||||||
|
|
||||||
caption {
|
|
||||||
padding-top: 0.75rem;
|
|
||||||
padding-bottom: 0.75rem;
|
|
||||||
color: #868e96;
|
|
||||||
text-align: left;
|
|
||||||
caption-side: bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
text-align: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
label {
|
|
||||||
display: inline-block;
|
|
||||||
margin-bottom: .5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
button:focus {
|
|
||||||
outline: 1px dotted;
|
|
||||||
outline: 5px auto -webkit-focus-ring-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
input,
|
|
||||||
button,
|
|
||||||
select,
|
|
||||||
optgroup,
|
|
||||||
textarea {
|
|
||||||
margin: 0;
|
|
||||||
font-family: inherit;
|
|
||||||
font-size: inherit;
|
|
||||||
line-height: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
input {
|
|
||||||
overflow: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
select {
|
|
||||||
text-transform: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
button,
|
|
||||||
html [type="button"],
|
|
||||||
[type="reset"],
|
|
||||||
[type="submit"] {
|
|
||||||
-webkit-appearance: button;
|
|
||||||
}
|
|
||||||
|
|
||||||
button::-moz-focus-inner,
|
|
||||||
[type="button"]::-moz-focus-inner,
|
|
||||||
[type="reset"]::-moz-focus-inner,
|
|
||||||
[type="submit"]::-moz-focus-inner {
|
|
||||||
padding: 0;
|
|
||||||
border-style: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="radio"],
|
|
||||||
input[type="checkbox"] {
|
|
||||||
box-sizing: border-box;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="date"],
|
|
||||||
input[type="time"],
|
|
||||||
input[type="datetime-local"],
|
|
||||||
input[type="month"] {
|
|
||||||
-webkit-appearance: listbox;
|
|
||||||
}
|
|
||||||
|
|
||||||
textarea {
|
|
||||||
overflow: auto;
|
|
||||||
resize: vertical;
|
|
||||||
}
|
|
||||||
|
|
||||||
fieldset {
|
|
||||||
min-width: 0;
|
|
||||||
padding: 0;
|
|
||||||
margin: 0;
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
legend {
|
|
||||||
display: block;
|
|
||||||
width: 100%;
|
|
||||||
max-width: 100%;
|
|
||||||
padding: 0;
|
|
||||||
margin-bottom: .5rem;
|
|
||||||
font-size: 1.5rem;
|
|
||||||
line-height: inherit;
|
|
||||||
color: inherit;
|
|
||||||
white-space: normal;
|
|
||||||
}
|
|
||||||
|
|
||||||
progress {
|
|
||||||
vertical-align: baseline;
|
|
||||||
}
|
|
||||||
|
|
||||||
[type="number"]::-webkit-inner-spin-button,
|
|
||||||
[type="number"]::-webkit-outer-spin-button {
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
[type="search"] {
|
|
||||||
outline-offset: -2px;
|
|
||||||
-webkit-appearance: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
[type="search"]::-webkit-search-cancel-button,
|
|
||||||
[type="search"]::-webkit-search-decoration {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
::-webkit-file-upload-button {
|
|
||||||
font: inherit;
|
|
||||||
-webkit-appearance: button;
|
|
||||||
}
|
|
||||||
|
|
||||||
output {
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
summary {
|
|
||||||
display: list-item;
|
|
||||||
}
|
|
||||||
|
|
||||||
template {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
[hidden] {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
/*# sourceMappingURL=bootstrap-reboot.css.map */
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue