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/*
|
||||
|
||||
.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"]
|
||||
path = themes/navy/layout/partial/shared-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: {
|
||||
src: {
|
||||
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: {
|
||||
css: './public/css',
|
||||
|
|
|
@ -63,43 +63,8 @@ $(document).ready(function () {
|
|||
|
||||
/* 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;
|
||||
}
|
||||
var addClassToElement = require('./shared-js/js/utils').addClassToElement;
|
||||
var removeClassFromElement = require('./shared-js/js/utils').removeClassFromElement;
|
||||
|
||||
/* Code highlighting */
|
||||
|
||||
|
@ -153,19 +118,4 @@ function showNav() {
|
|||
|
||||
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,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