Skip to content

Instantly share code, notes, and snippets.

@nesvand
Last active September 1, 2015 05:27
Show Gist options
  • Save nesvand/9f4c1276f55f91bf2989 to your computer and use it in GitHub Desktop.
Save nesvand/9f4c1276f55f91bf2989 to your computer and use it in GitHub Desktop.
Little Learners - Calendar
/* @calendar styling */
.events-list::-webkit-scrollbar {
-webkit-appearance: none;
width: 7px;
}
.events-list::-webkit-scrollbar-thumb {
border-radius: 4px;
background-color: rgba(0,0,0,.5);
-webkit-box-shadow: 0 0 1px rgba(255,255,255,.5);
}
#calendar-display {
font-family: Asap, Helvetica, Arial;
margin: 0 auto;
width: 100%;
-moz-box-shadow: 4px 4px 0 rgba(120, 119, 119, 0.9);
-webkit-box-shadow: 4px 4px 0 rgba(120, 119, 119, 0.9);
box-shadow: 4px 4px 0 rgba(120, 119, 119, 0.9);
}
#calendar-display .clndr {
overflow: hidden;
border-bottom: 7px solid #2FAFFC;
}
#calendar-display .clndr .controls {
background-color: #005383;
color: white;
}
#calendar-display .clndr .controls .clndr-previous-button,
#calendar-display .clndr .controls .clndr-next-button {
width: 15%;
padding-top: 5px;
padding-bottom: 5px;
display: inline-block;
text-align: center;
cursor: pointer;
-webkit-user-select: none;
/* Chrome/Safari */
-moz-user-select: none;
/* Firefox */
-ms-user-select: none;
/* IE10+ */
-webkit-transition: background-color 0.5s;
-moz-transition: background-color 0.5s;
-ms-transition: background-color 0.5s;
-o-transition: background-color 0.5s;
transition: background-color 0.5s;
}
#calendar-display .clndr .controls .clndr-previous-button:hover,
#calendar-display .clndr .controls .clndr-next-button:hover {
background-color: #006AA9;
}
#calendar-display .clndr .controls .month {
width: 70%;
padding-top: 5px;
padding-bottom: 5px;
display: inline-block;
text-align: center;
text-transform: uppercase;
font-weight: 700;
letter-spacing: 1px;
}
#calendar-display .clndr .days-container {
position: relative;
width: 100%;
height: 265px;
display: inline-block;
}
#calendar-display .clndr .days-container .days {
position: absolute;
left: 0;
width: 100%;
height: 270px;
-webkit-transition: left 0.5s;
-moz-transition: left 0.5s;
-ms-transition: left 0.5s;
-o-transition: left 0.5s;
transition: left 0.5s;
background-color: #ebebeb;
}
#calendar-display .clndr .days-container .days .day,
#calendar-display .clndr .days-container .days .empty {
width: 14.2857%;
display: inline-block;
height: 40px;
padding: 1em 0;
font-size: 12px;
text-align: center;
color: #212121;
background-color: #EBEBEB;
background-image: url();
background-size: cover;
background-position: center center;
border-right: 1px solid rgba(255, 255, 255, 0.5);
border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}
#calendar-display .clndr .days-container .days .day.event,
#calendar-display .clndr .days-container .days .empty.event {
background-color: #fff;
background-image: none;
-webkit-transition: background-color 0.5s;
-moz-transition: background-color 0.5s;
-ms-transition: background-color 0.5s;
-o-transition: background-color 0.5s;
transition: background-color 0.5s;
cursor: pointer;
}
#calendar-display .clndr .days-container .days .day.event:hover,
#calendar-display .clndr .days-container .days .empty.event:hover {
background-color: #b8b8b8;
}
#calendar-display .clndr .days-container .days .day.event .day-number,
#calendar-display .clndr .days-container .days .empty.event .day-number {
padding-bottom: 4px;
border-bottom: 2px solid #0097F1;
}
#calendar-display .clndr .days-container .days .day.adjacent-month,
#calendar-display .clndr .days-container .days .empty.adjacent-month {
color: rgba(0, 0, 0, 0.3);
}
#calendar-display .clndr .days-container .days .empty {
height: 31px;
vertical-align: bottom;
}
#calendar-display .clndr .days-container .days .headers {
background-color: #0097F1;
padding-top: 5px;
padding-bottom: 5px;
}
#calendar-display .clndr .days-container .days .headers .day-header {
width: 14.2857%;
display: inline-block;
text-align: center;
color: white;
}
#calendar-display .clndr .days-container .events {
position: absolute;
left: 100%;
width: 100%;
height: 270px;
-webkit-transition: left 0.5s;
-moz-transition: left 0.5s;
-ms-transition: left 0.5s;
-o-transition: left 0.5s;
transition: left 0.5s;
background-color: #ebebeb;
}
#calendar-display .clndr .days-container .events .headers {
position: relative;
}
#calendar-display .clndr .days-container .events .event-header {
width: 100%;
background-color: #0AA4FF;
padding-top: 5px;
padding-bottom: 5px;
text-align: center;
color: white;
}
#calendar-display .clndr .days-container .events .x-button {
position: absolute;
font-size: 80%;
top: 7px;
left: 20px;
cursor: pointer;
-webkit-transition: color 0.25s;
-moz-transition: color 0.25s;
-ms-transition: color 0.25s;
-o-transition: color 0.25s;
transition: color 0.25s;
}
#calendar-display .clndr .days-container .events .x-button:hover {
color: white;
}
#calendar-display .clndr .days-container .events .events-list {
overflow-y: scroll;
height: 240px;
}
#calendar-display .clndr .days-container .events .events-list .event {
padding-top: 1em;
padding-bottom: 1em;
padding-left: 10px;
border-bottom: 1px solid rgba(255, 255, 255, 0.5);
-webkit-transition: background-color 0.25s;
-moz-transition: background-color 0.25s;
-ms-transition: background-color 0.25s;
-o-transition: background-color 0.25s;
transition: background-color 0.25s;
}
#calendar-display .clndr .days-container .events .events-list .event:hover {
background-color: #f5f5f5;
}
#calendar-display .clndr .days-container .events .events-list .event a {
position: relative;
font-size: 12px;
letter-spacing: 1px;
background-color: transparent;
color: #212121;
text-decoration: none;
-webkit-transition: color 0.25s;
-moz-transition: color 0.25s;
-ms-transition: color 0.25s;
-o-transition: color 0.25s;
transition: color 0.25s;
}
#calendar-display .clndr .days-container .events .events-list .event a:hover {
background-color: transparent;
color: #006AA9;
}
#calendar-display .clndr .days-container.show-events .days {
left: -100%;
}
#calendar-display .clndr .days-container.show-events .events {
left: 0;
}
/* @calendar styling end */
<!-- Required JS Plugins -->
<!-- jQuery -->
<script type='text/javascript' src='http://cdn.myld.com.au/1/js/plugins/CLNDR/moment-2.5.1.min.js'></script>
<script type='text/javascript' src='http://cdn.myld.com.au/1/js/plugins/CLNDR/underscore.min.js'></script>
<script type='text/javascript' src='http://cdn.myld.com.au/1/js/plugins/CLNDR/clndr.min.js'></script>
<!-- Template -->
<script id="calendar-template" type="text/template">
<div class="controls">
<div class="clndr-previous-button">&lsaquo;</div><div class="month"><%= month %></div><div class="clndr-next-button">&rsaquo;</div>
</div>
<div class="days-container">
<div class="days">
<div class="headers">
<% _.each(daysOfTheWeek, function(day) { %><div class="day-header"><%= day %></div><% }); %>
</div>
<% _.each(days, function(day) { %><div class="<%= day.classes %>" id="<%= day.id %>"><span class="day-number"><%= day.day %></span></div><% }); %>
</div>
<div class="events">
<div class="headers">
<div class="x-button">x</div>
<div class="event-header">EVENTS</div>
</div>
<div class="events-list">
<% _.each(eventsThisMonth, function(event) { %>
<div class="event">
<a href="<%= event.url %>"><%= moment(event.date).format('MMMM Do') %>: <%= event.title %></a>
</div>
<% }); %>
</div>
</div>
</div>
</script>
<div id="calendar-display"></div>
/*************************/
/* Google-powered CLNDR.js
/*************************/
// Cross Reload Cookie Saving
if (JSON && JSON.stringify && JSON.parse) var Session = Session || (function() {
// Get stored cookie data
var cookie = sniffCookie();
function sniffCookie() {
var name = "store";
var result = document.cookie.match(new RegExp(name + '=([^;]+)'));
if (result)
return JSON.parse(result[1]);
return {};
}
function bakeCookie() {
var date = new Date();
var expires;
date.setTime(date.getTime() + (30 * 60 * 1000)); // 30 minute cookie
expires = "expires=" + date;
document.cookie = "store=" + JSON.stringify(cookie) + "; " + expires;
}
// page unload event
if (window.addEventListener) {
window.addEventListener("unload", bakeCookie, false);
} else if (window.attachEvent) {
window.attachEvent("onunload", bakeCookie);
} else {
window.onunload = bakeCookie;
}
// public methods
return {
// set a session variable
set: function(name, value) {
cookie[name] = value;
},
// get a session value
get: function(name) {
return (cookie[name] ? cookie[name] : undefined);
},
// clear session
clear: function() {
cookie = {};
}
};
})();
function loadCalendar(e) {
if (e) {
$('#calendar-display').clndr({
template: $('#calendar-template').html(),
events: e,
clickEvents: {
click: function(target) {
if (target.events.length) {
var daysContainer = $('#calendar-display').find('.days-container');
daysContainer.toggleClass('show-events', true);
$('#calendar-display').find('.x-button').click(function() {
daysContainer.toggleClass('show-events', false);
});
}
}
},
adjacentDaysChangeMonth: true,
forceSixRows: true
});
}
}
if ($('#calendar-display').length) {
var storedEvents = Session.get('events');
if (storedEvents === undefined) {
var googleCalendarURL = "https://www.googleapis.com/calendar/v3/calendars/littlelearners.dubbo.web%40gmail.com/events?singleEvents=true&key={redacted}";
var calendarReq = new XMLHttpRequest();
// Add timestamp to bypass cache
calendarReq.open('GET', googleCalendarURL + ((/\?/).test(googleCalendarURL) ? "&" : "?") + (new Date()).getTime(), true);
calendarReq.onreadystatechange = function() {
if (calendarReq.readyState == 4 && calendarReq.status >= 200 && calendarReq.status < 400) {
var calendarData = JSON.parse(calendarReq.responseText);
var calendarEvents = calendarData.items;
var len = calendarEvents.length;
var events = [];
var i;
for (i = 0; i < len; i++) {
var eventStartEnd = "";
if (calendarEvents[i].start.dateTime) {
var startHour = moment(calendarEvents[i].start.dateTime).hour();
var startMinute = ("0" + moment(calendarEvents[i].start.dateTime).minute()).slice(-2);
var endHour = moment(calendarEvents[i].end.dateTime).hour();
var endMinute = ("0" + moment(calendarEvents[i].end.dateTime).minute()).slice(-2);
eventStartEnd = " (" + startHour + ":" + startMinute + " - " + endHour + ":" + endMinute + ")";
}
events.push({
'date': calendarEvents[i].start.date || calendarEvents[i].start.dateTime,
'title': calendarEvents[i].summary + eventStartEnd,
'url': calendarEvents[i].htmlLink
});
}
loadCalendar(events);
Session.set('events', events);
} else {
loadCalendar(null);
}
};
calendarReq.send();
} else {
loadCalendar(storedEvents);
}
}
/*************************/
/* Google-powered CLNDR.js
/*************************/
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment