diff options
-rw-r--r-- | Contact.html | 69 | ||||
-rw-r--r-- | css/contact.css | 117 | ||||
-rw-r--r-- | css/menu.css | 327 | ||||
-rw-r--r-- | css/style.css | 143 | ||||
-rw-r--r-- | index.html | 83 | ||||
-rw-r--r-- | js/index.js | 93 | ||||
-rw-r--r-- | js/menu.js | 154 |
7 files changed, 986 insertions, 0 deletions
diff --git a/Contact.html b/Contact.html new file mode 100644 index 0000000..8dc7e52 --- /dev/null +++ b/Contact.html @@ -0,0 +1,69 @@ +<!DOCTYPE html> +<html lang="en" > + +<head> + <meta charset="UTF-8"> + <title>Contact Me</title> + + + + <link rel="stylesheet" href="css/menu.css"> + <link rel="stylesheet" href="css/contact.css"> + + +</head> + +<body> + <!-- Menu by Captain Anonymous who forked it from Dmitry Kiselyov--> + <div id='cssmenu'> + <ul> + <li><a href='#'>Home</a></li> + <li class='active'><a href='#'>Projects</a> + <ul> + <li><a href='https://navanchauhan.github.io/Mjolnir'>Mjölnir</a> + + </li> + <li><a href='https://navanchauhan.github.io/Grub-Repair-Toolkit'>GYGB</a> + + </li> + </ul> + </li> + </li> + <li><a href='./Contact.html'>Contact</a></li> + </ul> + </div> + <script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script> + + + + <script src="js/menu.js"></script> + + <div class="container"> + <form id="contact" action="http://formspree.io/navanchauhan@gmail.com" method="post"> + <h3>Quick Contact</h3> + <h4>Contact me today, and get a reply within 24 hours!</h4> + <fieldset> + <input placeholder="Your name" type="text" tabindex="1" required autofocus> + </fieldset> + <fieldset> + <input placeholder="Your Email Address" type="email" tabindex="2" name="_replyto" required> + </fieldset> + <fieldset> + <input placeholder="Your Phone Number" type="tel" tabindex="3" required> + </fieldset> + <fieldset> + <textarea placeholder="Type your Message Here...." tabindex="5" required></textarea> + </fieldset> + <fieldset> + <button name="submit" type="submit" value="Send" id="contact-submit" data-submit="...Sending">Submit</button> + </fieldset> + </form> + + +</div> + + + +</body> + +</html> diff --git a/css/contact.css b/css/contact.css new file mode 100644 index 0000000..33eefd3 --- /dev/null +++ b/css/contact.css @@ -0,0 +1,117 @@ +@import url(https://fonts.googleapis.com/css?family=Open+Sans:400italic,400,300,600); + +* { + margin:0; + padding:0; + box-sizing:border-box; + -webkit-box-sizing:border-box; + -moz-box-sizing:border-box; + -webkit-font-smoothing:antialiased; + -moz-font-smoothing:antialiased; + -o-font-smoothing:antialiased; + font-smoothing:antialiased; + text-rendering:optimizeLegibility; +} + +body { + font-family:"Open Sans", Helvetica, Arial, sans-serif; + font-weight:300; + font-size: 12px; + line-height:30px; + color:#777; + background: rgb(52, 152, 219); +} + +.container { + max-width:400px; + width:100%; + margin:0 auto; + position:relative; +} + +#contact input[type="text"], #contact input[type="email"], #contact input[type="tel"], #contact textarea, #contact button[type="submit"] { font:400 12px/16px "Open Sans", Helvetica, Arial, sans-serif; } + +#contact { + background:#F9F9F9; + padding:25px; + margin:50px 0; +} + +#contact h3 { + color: #F96; + font-size: 3em; + display: block; + font-weight: 300; +} + +#contact h4 { + margin:5px 0 15px; + display:block; + font-size:13px; +} + +fieldset { + border: medium none !important; + margin: 0 0 10px; + min-width: 100%; + padding: 0; + width: 100%; +} + +#contact input[type="text"], #contact input[type="email"], #contact input[type="tel"], #contact textarea { + width:100%; + border:1px solid #CCC; + background:#FFF; + margin:0 0 5px; + padding:10px; +} + +#contact input[type="text"]:hover, #contact input[type="email"]:hover, #contact input[type="tel"]:hover, #contact textarea:hover { + -webkit-transition:border-color 0.3s ease-in-out; + -moz-transition:border-color 0.3s ease-in-out; + transition:border-color 0.3s ease-in-out; + border:1px solid #AAA; +} + +#contact textarea { + height:100px; + max-width:100%; + resize:none; +} + +#contact button[type="submit"] { + cursor:pointer; + width:100%; + border:none; + background:rgb(52, 152, 219); + color:#FFF; + margin:0 0 5px; + padding:10px; + font-size:15px; +} + +#contact button[type="submit"]:hover { + background:#09C; + -webkit-transition:background 0.3s ease-in-out; + -moz-transition:background 0.3s ease-in-out; + transition:background-color 0.3s ease-in-out; +} + +#contact button[type="submit"]:active { box-shadow:inset 0 1px 3px rgba(0, 0, 0, 0.5); } + +#contact input:focus, #contact textarea:focus { + outline:0; + border:1px solid #999; +} +::-webkit-input-placeholder { + color:#888; +} +:-moz-placeholder { + color:#888; +} +::-moz-placeholder { + color:#888; +} +:-ms-input-placeholder { + color:#888; +} diff --git a/css/menu.css b/css/menu.css new file mode 100644 index 0000000..06c17fa --- /dev/null +++ b/css/menu.css @@ -0,0 +1,327 @@ +@import url(https://fonts.googleapis.com/css?family=Montserrat:400,700); +#cssmenu, +#cssmenu ul, +#cssmenu ul li, +#cssmenu ul li a, +#cssmenu #menu-button { + margin: 0; + padding: 0; + border: 0; + list-style: none; + line-height: 1; + display: block; + position: relative; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#cssmenu:after, +#cssmenu > ul:after { + content: "."; + display: block; + clear: both; + visibility: hidden; + line-height: 0; + height: 0; +} +#cssmenu #menu-button { + display: none; +} +#cssmenu { + font-family: Montserrat, sans-serif; + background: #373B44; +} +#cssmenu > ul > li { + float: left; +} +#cssmenu.align-center > ul { + font-size: 0; + text-align: center; +} +#cssmenu.align-center > ul > li { + display: inline-block; + float: none; +} +#cssmenu.align-center ul ul { + text-align: left; +} +#cssmenu.align-right > ul > li { + float: right; +} +#cssmenu > ul > li > a { + padding: 17px; + font-size: 12px; + letter-spacing: 1px; + text-decoration: none; + color: #dddddd; + font-weight: 700; + text-transform: uppercase; +} +#cssmenu > ul > li:hover > a { + color: #ffffff; +} +#cssmenu > ul > li.has-sub > a { + padding-right: 30px; +} +#cssmenu > ul > li.has-sub > a:after { + position: absolute; + top: 22px; + right: 11px; + width: 8px; + height: 2px; + display: block; + background: #dddddd; + content: ''; +} +#cssmenu > ul > li.has-sub > a:before { + position: absolute; + top: 19px; + right: 14px; + display: block; + width: 2px; + height: 8px; + background: #dddddd; + content: ''; + -webkit-transition: all .25s ease; + transition: all .25s ease; +} +#cssmenu > ul > li.has-sub:hover > a:before { + top: 23px; + height: 0; +} +#cssmenu ul ul { + position: absolute; + left: -9999px; +} +#cssmenu.align-right ul ul { + text-align: right; +} +#cssmenu ul ul li { + height: 0; + -webkit-transition: all .25s ease; + transition: all .25s ease; +} +#cssmenu li:hover > ul { + left: auto; +} +#cssmenu.align-right li:hover > ul { + left: auto; + right: 0; +} +#cssmenu li:hover > ul > li { + height: 35px; +} +#cssmenu ul ul ul { + margin-left: 100%; + top: 0; +} +#cssmenu.align-right ul ul ul { + margin-left: 0; + margin-right: 100%; +} +#cssmenu ul ul li a { + border-bottom: 1px solid rgba(150, 150, 150, 0.15); + padding: 11px 15px; + width: 170px; + font-size: 12px; + text-decoration: none; + color: #dddddd; + font-weight: 400; + background: #373B44; +} +#cssmenu ul ul li:last-child > a, +#cssmenu ul ul li.last-item > a { + border-bottom: 0; +} +#cssmenu ul ul li:hover > a, +#cssmenu ul ul li a:hover { + color: #ffffff; +} +#cssmenu ul ul li.has-sub > a:after { + position: absolute; + top: 16px; + right: 11px; + width: 8px; + height: 2px; + display: block; + background: #dddddd; + content: ''; +} +#cssmenu.align-right ul ul li.has-sub > a:after { + right: auto; + left: 11px; +} +#cssmenu ul ul li.has-sub > a:before { + position: absolute; + top: 13px; + right: 14px; + display: block; + width: 2px; + height: 8px; + background: #dddddd; + content: ''; + -webkit-transition: all .25s ease; + transition: all .25s ease; +} +#cssmenu.align-right ul ul li.has-sub > a:before { + right: auto; + left: 14px; +} +#cssmenu ul ul > li.has-sub:hover > a:before { + top: 17px; + height: 0; +} +@media all and (max-width: 768px), only screen and (-webkit-min-device-pixel-ratio: 2) and (max-width: 1024px), only screen and (min--moz-device-pixel-ratio: 2) and (max-width: 1024px), only screen and (min-device-pixel-ratio: 2) and (max-width: 1024px), only screen and (min-resolution: 192dpi) and (max-width: 1024px), only screen and (min-resolution: 2dppx) and (max-width: 1024px) { + #cssmenu { + width: 100%; + } + #cssmenu ul { + width: 100%; + display: none; + } + #cssmenu.align-center > ul { + text-align: left; + } + #cssmenu ul li { + width: 100%; + border-top: 1px solid rgba(120, 120, 120, 0.2); + } + #cssmenu ul ul li, + #cssmenu li:hover > ul > li { + height: auto; + } + #cssmenu ul li a, + #cssmenu ul ul li a { + width: 100%; + border-bottom: 0; + } + #cssmenu > ul > li { + float: none; + } + #cssmenu ul ul li a { + padding-left: 25px; + } + #cssmenu ul ul ul li a { + padding-left: 35px; + } + #cssmenu ul ul li a { + color: #dddddd; + background: none; + } + #cssmenu ul ul li:hover > a, + #cssmenu ul ul li.active > a { + color: #ffffff; + } + #cssmenu ul ul, + #cssmenu ul ul ul, + #cssmenu.align-right ul ul { + position: relative; + left: 0; + width: 100%; + margin: 0; + text-align: left; + } + #cssmenu > ul > li.has-sub > a:after, + #cssmenu > ul > li.has-sub > a:before, + #cssmenu ul ul > li.has-sub > a:after, + #cssmenu ul ul > li.has-sub > a:before { + display: none; + } + #cssmenu #menu-button { + display: block; + padding: 17px; + color: #dddddd; + cursor: pointer; + font-size: 12px; + text-transform: uppercase; + font-weight: 700; + } + #cssmenu #menu-button:after { + position: absolute; + top: 22px; + right: 17px; + display: block; + height: 4px; + width: 20px; + border-top: 2px solid #dddddd; + border-bottom: 2px solid #dddddd; + content: ''; + } + #cssmenu #menu-button:before { + position: absolute; + top: 16px; + right: 17px; + display: block; + height: 2px; + width: 20px; + background: #dddddd; + content: ''; + } + #cssmenu #menu-button.menu-opened:after { + top: 23px; + border: 0; + height: 2px; + width: 15px; + background: #ffffff; + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + } + #cssmenu #menu-button.menu-opened:before { + top: 23px; + background: #ffffff; + width: 15px; + -webkit-transform: rotate(-45deg); + transform: rotate(-45deg); + } + #cssmenu .submenu-button { + position: absolute; + z-index: 99; + right: 0; + top: 0; + display: block; + border-left: 1px solid rgba(120, 120, 120, 0.2); + height: 46px; + width: 46px; + cursor: pointer; + } + #cssmenu .submenu-button.submenu-opened { + background: #262626; + } + #cssmenu ul ul .submenu-button { + height: 34px; + width: 34px; + } + #cssmenu .submenu-button:after { + position: absolute; + top: 22px; + right: 19px; + width: 8px; + height: 2px; + display: block; + background: #dddddd; + content: ''; + } + #cssmenu ul ul .submenu-button:after { + top: 15px; + right: 13px; + } + #cssmenu .submenu-button.submenu-opened:after { + background: #ffffff; + } + #cssmenu .submenu-button:before { + position: absolute; + top: 19px; + right: 22px; + display: block; + width: 2px; + height: 8px; + background: #dddddd; + content: ''; + } + #cssmenu ul ul .submenu-button:before { + top: 12px; + right: 16px; + } + #cssmenu .submenu-button.submenu-opened:before { + display: none; + } +} diff --git a/css/style.css b/css/style.css new file mode 100644 index 0000000..4aac7ae --- /dev/null +++ b/css/style.css @@ -0,0 +1,143 @@ +* { + box-sizing: border-box; +} + +body { + margin: 0; + font-weight: 500; + font-family: 'HelveticaNeue'; +} + +section { + width: 100%; + padding: 0 7%; + display: table; + margin: 0; + max-width: none; + background-color: #373B44; + height: 100vh; +} +section:nth-of-type(2n) { + background-color: rgb(52, 152, 219); +} + +.intro { + height: 90vh; +} + +.content { + display: table-cell; + vertical-align: middle; +} + +h1 { + font-size: 3em; + display: block; + color: white; + font-weight: 300; +} + +p { + font-size: 1.5em; + font-weight: 500; + color: #C3CAD9; +} + +a { + font-weight: 700; + color: #373B44; + position: relative; +} +a:hover { + opacity: 0.8; +} +a:active { + top: 1px; +} + +footer { + padding: 1% 5%; + text-align: center; + background-color: #373B44; + color: white; +} +footer a { + color: #FE4B74; + font-weight: 500; + text-decoration: none; +} + +@-webkit-keyframes letter-in { + 0% { + top: 1.2em; + } + 100% { + top: 0em; + } +} + +@keyframes letter-in { + 0% { + top: 1.2em; + } + 100% { + top: 0em; + } +} +@-webkit-keyframes letter-out { + 0% { + top: 0em; + } + 100% { + top: -1.2em; + } +} +@keyframes letter-out { + 0% { + top: 0em; + } + 100% { + top: -1.2em; + } +} +div.changing-title { + font-size: 8vw; + height: 1.2em; + position: relative; + width: 100%; + overflow-y: hidden; + margin-left: 1em; + transform: translate3d(0, 0, 0); +} +div.changing-title h1 { + font-size: 1em; + position: absolute; + left: 0; + top: 0; + margin: 0; +} +div.changing-title h1 .letter { + position: relative; + top: 1.2em; +} +div.changing-title h1 .letter.in { + -webkit-animation-name: letter-in; + animation-name: letter-in; + -webkit-animation-duration: 0.3s; + animation-duration: 0.3s; + -webkit-animation-timing-function: ease-out; + animation-timing-function: ease-out; + -webkit-animation-fill-mode: forwards; + animation-fill-mode: forwards; +} +div.changing-title h1 .letter.out { + top: 0em; + -webkit-animation-name: letter-out; + animation-name: letter-out; + -webkit-animation-duration: 0.3s; + animation-duration: 0.3s; + -webkit-animation-timing-function: ease-in; + animation-timing-function: ease-in; + -webkit-animation-fill-mode: forwards; + animation-fill-mode: forwards; +} diff --git a/index.html b/index.html new file mode 100644 index 0000000..47484b0 --- /dev/null +++ b/index.html @@ -0,0 +1,83 @@ +<!DOCTYPE html> +<html lang="en" > + +<head> + <meta charset="UTF-8"> + <title>Hi!</title> + + + + <link rel="stylesheet" href="css/style.css"> + <link rel="stylesheet" href="css/menu.css"> + + +</head> + +<body> + <!-- Menu by Captain Anonymous who forked it from Dmitry Kiselyov--> + <div id='cssmenu'> +<ul> + <li><a href='#'>Home</a></li> + <li class='active'><a href='#'>Projects</a> + <ul> + <li><a href='https://navanchauhan.github.io/Mjolnir'>Mjölnir</a> + + </li> + <li><a href='https://navanchauhan.github.io/Grub-Repair-Toolkit'>GYGB</a> + + </li> + </ul> + </li> + </li> + <li><a href='./Contact.html'>Contact</a></li> +</ul> +</div> + <script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script> + + + + <script src="js/menu.js"></script> + + + <section class="intro"> +<!--Sections created by ckor https://twitter.com/ckor --> + <div class="content"><!--Changing Header by Austin Dudas--> + <div class="changing-title"><h1>Hi! I am Navan</h1></div></h1> + + + + <script src="js/index.js"></script> + <script src="js/fm.js"></script> + + + </div> +</section> + +<section> + <div class="content"> + <h1>I started coding when I was 8 and ironically learnt C before HTML</h1> + </div> +</section> + +<section> + + <div class="content"> + <h1>Funnily, I learnt C# before HTML</h1> + </div> +</section> + +<section> + <div class="content"> + <h1>See my <a href="https://github.com/navanchauhan">GitHub Repo.</a></h1> + </div> +</section> + +<footer> + Helped by countless designers, check source code for more info</a> +</footer> + + + +</body> + +</html> diff --git a/js/index.js b/js/index.js new file mode 100644 index 0000000..c5340b8 --- /dev/null +++ b/js/index.js @@ -0,0 +1,93 @@ +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +var ChangingTitle = function () { + function ChangingTitle() { + var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; + + _classCallCheck(this, ChangingTitle); + + this.node = x; + this.letterfy(this.node.querySelector('h1')); + } + + _createClass(ChangingTitle, [{ + key: 'letterfy', + value: function letterfy(node) { + var text = node.innerText; + node.innerText = ''; + node.classList.add('current'); + for (var c in text) { + var span = document.createElement('span'); + span.innerText = text[c]; + span.classList.add('letter', 'in'); + span.style.animationDelay = c * 0.1 + 's'; + node.appendChild(span); + } + } + }, { + key: 'changeText', + value: function changeText(newText) { + var oldTitle = this.node.querySelector('.current'); + var i = 0; + var _iteratorNormalCompletion = true; + var _didIteratorError = false; + var _iteratorError = undefined; + + try { + for (var _iterator = oldTitle.children[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { + var letter = _step.value; + + letter.style.animationDelay = i++ * 0.1 + 's'; + letter.classList.remove('in'); + letter.classList.add('out'); + } + } catch (err) { + _didIteratorError = true; + _iteratorError = err; + } finally { + try { + if (!_iteratorNormalCompletion && _iterator.return) { + _iterator.return(); + } + } finally { + if (_didIteratorError) { + throw _iteratorError; + } + } + } + + oldTitle.classList.remove('current'); + var newTitle = document.createElement('h1'); + newTitle.classList.add('current'); + for (var c in newText) { + var span = document.createElement('span'); + span.innerText = newText[c]; + span.classList.add('letter', 'in'); + span.style.animationDelay = c * 0.1 + 0.5 + 's'; + newTitle.appendChild(span); + } + this.node.appendChild(newTitle); + setTimeout(this.removeNode(oldTitle), 2000); + } + }, { + key: 'removeNode', + value: function removeNode(x) { + return function () { + x.remove(); + }; + } + }]); + + return ChangingTitle; +}(); + +; + +var ct = new ChangingTitle(document.querySelector('.changing-title')); +var texts = ['Hi! I am नवन']; +var count = 0; +setInterval(function () { + ct.changeText(texts[++count % texts.length]); +}, 2000); diff --git a/js/menu.js b/js/menu.js new file mode 100644 index 0000000..6c0ab53 --- /dev/null +++ b/js/menu.js @@ -0,0 +1,154 @@ +(function($) { + + /* + Responsive Flat Menu + http://cssmenumaker.com/menu/responsive-flat-menu + */ + + $.fn.menumaker = function(options) { + + var cssmenu = $(this), + settings = $.extend({ + title: "Menu", + format: "dropdown", + sticky: false + }, options); + + return this.each(function() { + cssmenu.prepend('<div id="menu-button">' + settings.title + '</div>'); + $(this).find("#menu-button").on('click', function() { + $(this).toggleClass('menu-opened'); + var mainmenu = $(this).next('ul'); + if (mainmenu.hasClass('open')) { + mainmenu.hide().removeClass('open'); + } else { + mainmenu.show().addClass('open'); + if (settings.format === "dropdown") { + mainmenu.find('ul').show(); + } + } + }); + + cssmenu.find('li ul').parent().addClass('has-sub'); + + multiTg = function() { + cssmenu.find(".has-sub").prepend('<span class="submenu-button"></span>'); + cssmenu.find('.submenu-button').on('click', function() { + $(this).toggleClass('submenu-opened'); + if ($(this).siblings('ul').hasClass('open')) { + $(this).siblings('ul').removeClass('open').hide(); + } else { + $(this).siblings('ul').addClass('open').show(); + } + }); + }; + + if (settings.format === 'multitoggle') multiTg(); + else cssmenu.addClass('dropdown'); + + if (settings.sticky === true) cssmenu.css('position', 'fixed'); + + resizeFix = function() { + if ($(window).width() > 768) { + cssmenu.find('ul').show(); + } + + if ($(window).width() <= 768) { + cssmenu.find('ul').hide().removeClass('open'); + } + }; + resizeFix(); + return $(window).on('resize', resizeFix); + + }); + }; +})(jQuery); + +/* + By Osvaldas Valutis, www.osvaldas.info + Available for use under the MIT License +*/ + +; +(function($, window, document, undefined) { + $.fn.doubleTapToGo = function(params) { + if (!('ontouchstart' in window) && + !navigator.msMaxTouchPoints && + !navigator.userAgent.toLowerCase().match(/windows phone os 7/i)) return false; + + this.each(function() { + var curItem = false; + + $(this).on('click', function(e) { + var item = $(this); + if (item[0] != curItem[0]) { + e.preventDefault(); + curItem = item; + } + }); + + $(document).on('click touchstart MSPointerDown', function(e) { + var resetItem = true, + parents = $(e.target).parents(); + + for (var i = 0; i < parents.length; i++) + if (parents[i] == curItem[0]) + resetItem = false; + + if (resetItem) + curItem = false; + }); + }); + return this; + }; +})(jQuery, window, document); + +/** + * doubleTapToGoDecorator + * Adds the ability to remove the need for a second tap + * when in the mobile view + * + * @param {function} f - doubleTapToGo + */ +function doubleTapToGoDecorator(f) { + return function() { + + this.each(function() { + $(this).on('click', function(e) { + + // If mobile menu view + if ($('#menu-button').css('display') == 'block') { + + // If this is not a submenu button + if (!$(e.target).hasClass('submenu-button')) { + + // Remove the need for a second tap + window.location.href = $(e.target).attr('href'); + } + } + + }); + }); + + return f.apply(this); + } +} + +// Add decorator to the doubleTapToGo plugin +jQuery.fn.doubleTapToGo = doubleTapToGoDecorator(jQuery.fn.doubleTapToGo); + +/** + * jQuery + */ +(function($) { + $(document).ready(function() { + + $("#cssmenu").menumaker({ + title: "Menu", + format: "multitoggle" + }); + + $('#cssmenu li:has(ul)').doubleTapToGo(); + + }); +})(jQuery);
\ No newline at end of file |