Merge pull request #25 from samthomson/refactor/use-shared-js
refactor/use-shared-js
This commit is contained in:
commit
916bc49d81
|
@ -54,4 +54,8 @@ packages/*
|
||||||
.vagrant
|
.vagrant
|
||||||
.vagrant/*
|
.vagrant/*
|
||||||
|
|
||||||
.env
|
.env
|
||||||
|
|
||||||
|
# built assets
|
||||||
|
themes/navy/source/js/vendor.js
|
||||||
|
themes/navy/source/js/vendor.js.map
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
[submodule "themes/navy/layout/partial/shared-partials"]
|
[submodule "themes/navy/layout/partial/shared-partials"]
|
||||||
path = themes/navy/layout/partial/shared-partials
|
path = themes/navy/layout/partial/shared-partials
|
||||||
url = https://github.com/status-im/status.im-partials
|
url = https://github.com/status-im/status.im-partials
|
||||||
|
[submodule "themes/navy/source/js/shared-js"]
|
||||||
|
path = themes/navy/source/js/shared-js
|
||||||
|
url = git@github.com:status-im/status-im-js.git
|
||||||
|
|
|
@ -37,7 +37,11 @@ var config = {
|
||||||
paths: {
|
paths: {
|
||||||
src: {
|
src: {
|
||||||
scss: './themes/navy/source/scss/*.scss',
|
scss: './themes/navy/source/scss/*.scss',
|
||||||
js: './themes/navy/source/js/main.js',
|
js: [
|
||||||
|
'./themes/navy/source/js/shared-js/js/utils.js',
|
||||||
|
'./themes/navy/source/js/shared-js/js/popups.js',
|
||||||
|
'./themes/navy/source/js/main.js',
|
||||||
|
]
|
||||||
},
|
},
|
||||||
dist: {
|
dist: {
|
||||||
css: './public/css',
|
css: './public/css',
|
||||||
|
|
|
@ -63,43 +63,8 @@ $(document).ready(function () {
|
||||||
|
|
||||||
/* Popups */
|
/* Popups */
|
||||||
|
|
||||||
let community = document.querySelectorAll(".item--dropdown-community")[0]
|
var addClassToElement = require('./shared-js/js/utils').addClassToElement;
|
||||||
let projects = document.querySelectorAll(".item--dropdown-projects")[0]
|
var removeClassFromElement = require('./shared-js/js/utils').removeClassFromElement;
|
||||||
|
|
||||||
let popups = document.querySelectorAll(".popup-wrap")
|
|
||||||
let overlays = document.querySelectorAll(".popup-overlay")
|
|
||||||
let closeButtons = document.querySelectorAll(".popup__button--close")
|
|
||||||
|
|
||||||
let activePopup = null;
|
|
||||||
let activeOverlay = null;
|
|
||||||
|
|
||||||
community.addEventListener('click', function(event){
|
|
||||||
showPopup(popups[0])
|
|
||||||
event.preventDefault()
|
|
||||||
})
|
|
||||||
|
|
||||||
projects.addEventListener('click', function(event){
|
|
||||||
showPopup(popups[1])
|
|
||||||
event.preventDefault()
|
|
||||||
})
|
|
||||||
|
|
||||||
closeButtons.forEach((button) => {
|
|
||||||
button.addEventListener('click', closeActivePopup)
|
|
||||||
})
|
|
||||||
|
|
||||||
overlays.forEach((overlay) => {
|
|
||||||
overlay.addEventListener('click', closeActivePopup)
|
|
||||||
})
|
|
||||||
|
|
||||||
function showPopup(whichPopup) {
|
|
||||||
activePopup = whichPopup
|
|
||||||
addClassToElement(whichPopup, "popup--shown");
|
|
||||||
}
|
|
||||||
|
|
||||||
function closeActivePopup() {
|
|
||||||
removeClassFromElement(activePopup, "popup--shown");
|
|
||||||
activePopup = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Code highlighting */
|
/* Code highlighting */
|
||||||
|
|
||||||
|
@ -153,19 +118,4 @@ function showNav() {
|
||||||
|
|
||||||
function closeNav() {
|
function closeNav() {
|
||||||
removeClassFromElement(nav, "mobile-nav--shown");
|
removeClassFromElement(nav, "mobile-nav--shown");
|
||||||
}
|
}
|
||||||
|
|
||||||
/*--- Utils ---*/
|
|
||||||
function addClassToElement(element, className) {
|
|
||||||
(element.classList) ? element.classList.add(className) : element.className += ' ' + className
|
|
||||||
return element
|
|
||||||
}
|
|
||||||
|
|
||||||
function removeClassFromElement(element, className) {
|
|
||||||
if(element.classList) {
|
|
||||||
element.classList.remove(className)
|
|
||||||
} else {
|
|
||||||
element.className = element.className.replace(new RegExp('(^|\\b)' + className.split(' ').join('|') + '(\\b|$)', 'gi'), ' ')
|
|
||||||
}
|
|
||||||
return element
|
|
||||||
}
|
|
|
@ -1,172 +0,0 @@
|
||||||
(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
|
|
||||||
$(document).ready(function () {
|
|
||||||
|
|
||||||
// Fixes Parallax effect and div to popup overlapping with the main menu options
|
|
||||||
$('div#container').append($('.popup-wrap.popup-wrap--community')[0]);
|
|
||||||
$('div#container').append($('.popup-wrap.popup-wrap--projects')[0]);
|
|
||||||
|
|
||||||
let url = 'https://our.status.im/ghost/api/v0.1/posts/?filter=tag:nimbus&order=published_at%20desc&limit=3&formats=plaintext&client_id=ghost-frontend&client_secret=2b055fcd57ba';
|
|
||||||
var urlBase = [location.protocol, '//', location.host, location.pathname].join('');
|
|
||||||
|
|
||||||
$.ajax({
|
|
||||||
type: "get",
|
|
||||||
url: url,
|
|
||||||
success: function (response) {
|
|
||||||
response.posts = response.posts.reverse();
|
|
||||||
$.each(response.posts, function (index, val) {
|
|
||||||
var excerpt = '';
|
|
||||||
if (val.custom_excerpt != null) {
|
|
||||||
excerpt = val.custom_excerpt;
|
|
||||||
} else {
|
|
||||||
excerpt = getWords(val.plaintext);
|
|
||||||
}
|
|
||||||
$('.contribute-wrap-blog').prepend('<div class="contribute blog"><a href="https://our.status.im/' + val.slug + '" class="feature-image"><img src="https://our.status.im/' + val.feature_image + '" alt="' + val.title + '"></a><h3><a href="https://our.status.im/' + val.slug + '">' + val.title + '</a></h3><p>' + excerpt + '</p><a href="https://our.status.im/' + val.slug + '">Read More <img src="' + urlBase + '/img/arrow_ogn.png" /></a></div>');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
function getWords(str) {
|
|
||||||
return str.split(/\s+/).slice(0, 25).join(" ");
|
|
||||||
}
|
|
||||||
|
|
||||||
var months = { '01': 'Jan', '02': 'Feb', '03': 'Mar', '04': 'Apr', '05': 'May', '06': 'Jun', '07': 'Jul', '08': 'Aug', '09': 'Sep', '10': 'Oct', '11': 'Nov', '12': 'Dec' };
|
|
||||||
url = 'https://our.status.im/ghost/api/v0.1/posts/?order=published_at%20desc&limit=2&formats=plaintext&client_id=ghost-frontend&client_secret=2b055fcd57ba';
|
|
||||||
|
|
||||||
$.ajax({
|
|
||||||
type: "get",
|
|
||||||
url: url,
|
|
||||||
success: function (response) {
|
|
||||||
response.posts = response.posts.reverse();
|
|
||||||
$.each(response.posts, function (index, val) {
|
|
||||||
var excerpt = '';
|
|
||||||
if (val.custom_excerpt != null) {
|
|
||||||
excerpt = val.custom_excerpt;
|
|
||||||
} else {
|
|
||||||
excerpt = getWords(val.plaintext);
|
|
||||||
}
|
|
||||||
var newDate = new Date(val.published_at);
|
|
||||||
var minutes = newDate.getMinutes();
|
|
||||||
minutes = minutes + "";
|
|
||||||
if (minutes.length == 1) {
|
|
||||||
minutes = '0' + minutes;
|
|
||||||
}
|
|
||||||
$('.latest-posts').prepend(' \
|
|
||||||
<div class="post"> \
|
|
||||||
<time>' + newDate.getDate() + ' ' + months[newDate.getMonth() + 1] + ' at ' + newDate.getHours() + ':' + minutes + '</time> \
|
|
||||||
<h4><a href="https://our.status.im/' + val.slug + '">' + val.title + '</a></h3> \
|
|
||||||
</div> \
|
|
||||||
');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
/* Popups */
|
|
||||||
|
|
||||||
let community = document.querySelectorAll(".item--dropdown-community")[0];
|
|
||||||
let projects = document.querySelectorAll(".item--dropdown-projects")[0];
|
|
||||||
|
|
||||||
let popups = document.querySelectorAll(".popup-wrap");
|
|
||||||
let overlays = document.querySelectorAll(".popup-overlay");
|
|
||||||
let closeButtons = document.querySelectorAll(".popup__button--close");
|
|
||||||
|
|
||||||
let activePopup = null;
|
|
||||||
let activeOverlay = null;
|
|
||||||
|
|
||||||
community.addEventListener('click', function (event) {
|
|
||||||
showPopup(popups[0]);
|
|
||||||
event.preventDefault();
|
|
||||||
});
|
|
||||||
|
|
||||||
projects.addEventListener('click', function (event) {
|
|
||||||
showPopup(popups[1]);
|
|
||||||
event.preventDefault();
|
|
||||||
});
|
|
||||||
|
|
||||||
closeButtons.forEach(button => {
|
|
||||||
button.addEventListener('click', closeActivePopup);
|
|
||||||
});
|
|
||||||
|
|
||||||
overlays.forEach(overlay => {
|
|
||||||
overlay.addEventListener('click', closeActivePopup);
|
|
||||||
});
|
|
||||||
|
|
||||||
function showPopup(whichPopup) {
|
|
||||||
activePopup = whichPopup;
|
|
||||||
addClassToElement(whichPopup, "popup--shown");
|
|
||||||
}
|
|
||||||
|
|
||||||
function closeActivePopup() {
|
|
||||||
removeClassFromElement(activePopup, "popup--shown");
|
|
||||||
activePopup = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Code highlighting */
|
|
||||||
|
|
||||||
function highlight() {
|
|
||||||
$('pre code').each(function (i, block) {
|
|
||||||
hljs.highlightBlock(block);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
$(document).ready(function () {
|
|
||||||
try {
|
|
||||||
highlight();
|
|
||||||
} catch (err) {
|
|
||||||
console.log("retrying...");
|
|
||||||
setTimeout(function () {
|
|
||||||
highlight();
|
|
||||||
}, 2500);
|
|
||||||
}
|
|
||||||
|
|
||||||
var clipboard = new ClipboardJS(".btn");
|
|
||||||
clipboard.on('success', function (e) {
|
|
||||||
var id = $(e.trigger).attr("data-clipboard-target");
|
|
||||||
$(id).toggleClass("flash");
|
|
||||||
setTimeout(function () {
|
|
||||||
$(id).toggleClass("flash");
|
|
||||||
}, 200);
|
|
||||||
e.clearSelection();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
/* Mobile Nav */
|
|
||||||
|
|
||||||
let moreLink = document.querySelectorAll(".item--more")[0];
|
|
||||||
|
|
||||||
let nav = document.querySelectorAll(".mobile-nav-wrap")[0];
|
|
||||||
let navOverlay = document.querySelectorAll(".mobile-nav-overlay")[0];
|
|
||||||
let navCloseButton = document.querySelectorAll(".mobile-nav-close")[0];
|
|
||||||
|
|
||||||
moreLink.addEventListener('click', function (event) {
|
|
||||||
showNav();
|
|
||||||
event.preventDefault();
|
|
||||||
});
|
|
||||||
|
|
||||||
navCloseButton.addEventListener('click', closeNav);
|
|
||||||
navOverlay.addEventListener('click', closeNav);
|
|
||||||
|
|
||||||
function showNav() {
|
|
||||||
addClassToElement(nav, "mobile-nav--shown");
|
|
||||||
}
|
|
||||||
|
|
||||||
function closeNav() {
|
|
||||||
removeClassFromElement(nav, "mobile-nav--shown");
|
|
||||||
}
|
|
||||||
|
|
||||||
/*--- Utils ---*/
|
|
||||||
function addClassToElement(element, className) {
|
|
||||||
element.classList ? element.classList.add(className) : element.className += ' ' + className;
|
|
||||||
return element;
|
|
||||||
}
|
|
||||||
|
|
||||||
function removeClassFromElement(element, className) {
|
|
||||||
if (element.classList) {
|
|
||||||
element.classList.remove(className);
|
|
||||||
} else {
|
|
||||||
element.className = element.className.replace(new RegExp('(^|\\b)' + className.split(' ').join('|') + '(\\b|$)', 'gi'), ' ');
|
|
||||||
}
|
|
||||||
return element;
|
|
||||||
}
|
|
||||||
|
|
||||||
},{}]},{},[1])
|
|
||||||
//# sourceMappingURL=vendor.js.map
|
|
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue