This example shows how to use the Calendar Grouping Strategy with the Grid Layout Engine to present a data set as a calendar, with data-defined events added to the corresponding days in the calendar.
This calendar is also editable.
The Calendar Grouping Strategy creates one visual group per date and when it is used with the grid, you get a convenient calendar view.
To make the Calendar Grouping Strategy with the grid, you must have one group level and the grouped column must be a date.
In this example, the grouped column is the start column. Data in the start group is placed on the calendar on that day.
Note the following in the code:
References to calendar.js and grid.js load the libraries.
CalendarGrouping object configures the calendar view.
dataView object configures the data presentation and sets the grouping policy.
<!DOCTYPE html>
<html lang="en">
<head>
<base href="/dataviewsjs/demos/en/sample/DataViews/Calendar/Calendar/purejs/" />
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="keywords" content="grouping, calendar" />
<meta
name="description"
content="This example shows how to use the Calendar Grouping Strategy with the Grid Layout Engine to present a data set as a calendar, with data-defined events added to the corresponding days in the calendar."
/>
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Calendar | Data Views | MESCIUS DataViewsJS JavaScript Demos</title>
<link href="/dataviewsjs/demos/node_modules/normalize.css/normalize.css" rel="stylesheet" type="text/css" />
<link href="/dataviewsjs/demos/static/css/base.css" rel="stylesheet" type="text/css" />
<link href="/dataviewsjs/demos/static/css/bootstrap-snippet.min.css" rel="stylesheet" type="text/css" />
<link
href="/dataviewsjs/demos/node_modules/@fortawesome/fontawesome-free/css/all.min.css"
rel="stylesheet"
type="text/css"
/>
<link href="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.css" rel="stylesheet" type="text/css" />
<link href="/dataviewsjs/demos/static/dataviews/gc.dataviews.calendar.min.css" rel="stylesheet" type="text/css" />
<link href="/dataviewsjs/demos/static/dataviews/gc.dataviews.grid.min.css" rel="stylesheet" type="text/css" />
<link href="styles.css" rel="stylesheet" type="text/css" />
<script src="/dataviewsjs/demos/static/js/app-polyfills.min.js" type="text/javascript"></script>
<script type="text/javascript">
window.process = {
env: {
NODE_ENV: 'production',
USE_NPM: false,
USE_CDN: false,
SITE_ROOT: '/dataviewsjs/demos',
FRAMEWORK: 'purejs',
DVJS_LICENSE_KEY:
'E348418822993781#B0EWvwY4dNNVQqJHUDpFROVWe5ZWNYFlVQFmRsJWRht4Z6lDO4Vla7YUaXhEWxd7Z5YXMuRnY7tWTQRHSlVnaYlXNhlEOpdkZ0FHWYJ5QKd6VXN5aR3ieGhUav9kZTBXWahkYBhEVutmZ72CbjdlZvV5TVdGdiplQsZXe95kUmNmZVF5cJ3mcypWNyx4UydESE3UblxGZyE7KQ94R4BjbUxUewsiaoREMxRDNllWREV6Voh4Q4dDZPRjWrIzUJl4TERXcQZWMHp4Sp9WaMZzN5o6StJmVDJXcwIVVmR6UMVGOlxUW8RmTxZDZTJWVN5GZqJHZuVDMkVGSW3WdxNzKCdDdSB7TzY7cqlnMU5GVyNzNP9WMyhDRvEEOFdkQORDM4dFVlFFWqFWSyMjNQJiOiMlIsISQyIkQ9YjQxIiOigkIsUTM7YjNxYTM0IicfJye&Qf35VfikFVVljI0IyQiwiIxYHITp4c7VWaWFGdhRkI0IiTis7W0ICZyBlIsIiNxUTN6ADI8EDMxMjMwIjI0ICdyNkIsIyc59yc5l6YzVWbuoCLwpmLzVXajNXZt9iKs2WauMXdpN6cl5mLqwSbvNmLzVXajNXZt9iKsAnau26YuMXdpN6cl5mLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLuNmLt36YukHdpNWZwFmcn9iKs46bj9Se4l6YlBXYydmLqwicr9ybj9Se4l6YlBXYydmLqwCcq9ybj9Se4l6YlBXYydmLqIiOiMXbEJCLiMVVJN4UF5kI0ISYONkIsUWdyRnOiwmdFJCLiEDO7MTO9IjM8gTM4gDNzIiOiQWSisnOiQkIsISP3EkVxBVUHFDMplzLlVUdGd7cI9UeIt4SshESzV7NvY7ZxlDOuNTb5tzLr',
SJS_LICENSE_KEY:
'E518585142165236#B0wm4nx4QzdlTHRTSOFzcvVnaJdjSnNEeXdTMUtSUzk6bU94QuVXNwZVZjd4SzYjcadXRIVEMzEXTThkVyR7R85UayoHZZBTYQ5mZyh4Shd6VxFXazF4cBNGRG5WTvUGTsV4T6knQYRzKxxUdk9EarplU7d6VLF6KIR7bPJ5N6ZUMWZWaURGRKRDbLJDN5YjSN5mUoxmaxonSD56LEh7Y7RXenpmTvomevZlV9dkaysCO7hTRQFHcGRWQyc5LI9kQmB7QwR4Z7ZHOR3CSXp6SiFWYzFXeXZUSp94K8VDTkFjdwl4KptSYlRWcDxmNE5kS6kzdrkVcNJXROVGbLJkcTNGRzIER8tmd4YGNhh7dxAnMvIHRv46VtBXS4U5KvJ6dZJ6M5p4TxIjd9I5QSpXTTV6SDZXb7lzaL56ZiojITJCLikTQxUTQFV4NiojIIJCLyETO7UzM7kTO0IicfJye&Qf35VfikkR9IkI0IyQiwiIyEjL6ByUKBCZhVmcwNlI0IiTis7W0ICZyBlIsISNwkTN6ADI8EDMxMjMwIjI0ICdyNkIsIyc59yc5l6YzVWbuoCLwpmLzVXajNXZt9iKs2WauMXdpN6cl5mLqwSbvNmLzVXajNXZt9iKsAnau26YuMXdpN6cl5mLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLuNmLt36YukHdpNWZwFmcn9iKs46bj9Se4l6YlBXYydmLqwicr9ybj9Se4l6YlBXYydmLqwCcq9ybj9Se4l6YlBXYydmLqIiOiMXbEJCLiMVVJN4UF5kI0ISYONkIsUWdyRnOiwmdFJCLiYzMyUjNxIDNxUDO5gTM5IiOiQWSiwSfdtlOicGbmJCLlNHbhZmOiI7ckJye0ICbuFkI1pjIEJCLi4TPRtGOhtWWEFWd4IDOLRVRvx4SyMGcDhTW6n4ep',
},
};
</script>
<script src="/dataviewsjs/demos/node_modules/lodash/lodash.min.js" type="text/javascript"></script>
<script src="/dataviewsjs/demos/node_modules/jquery/dist/jquery.min.js" type="text/javascript"></script>
<script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.common.min.js" type="text/javascript"></script>
<script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.js" type="text/javascript"></script>
<script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.calendar.min.js" type="text/javascript"></script>
<script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.grid.min.js" type="text/javascript"></script>
<script src="/dataviewsjs/demos/static/js/license.js" type="text/javascript"></script>
</head>
<body class="theme-default">
<noscript>You need to enable JavaScript to run this app.</noscript>
<template id="editDialogTemplate" style="display: none">
<div class="backdrop">
<div class="editEventDialog">
<div class="editEventBackground">
<div class="editEventHeaderInner">
<div class="header">Edit Event</div>
<div class="gc-editing-close gc-float-right" onclick="removeDialog(event)">
<span class="fa fa-times"></span>
</div>
</div>
</div>
<div class="editEventContent">
<div class="contentItem">
<div class="title fixed"><label>Title</label></div>
<div class="input-container">
<input id="eventTitleContent" />
</div>
</div>
<div class="contentItem">
<div class="title fixed"><label>When</label></div>
<div class="input-container">
<div class="input-group date">
<input type="time" id="datetimepicker1" />
</div>
</div>
<div class="title"><label>to</label></div>
<div class="input-container">
<div class="input-group date">
<input type="time" id="datetimepicker2" />
</div>
</div>
</div>
</div>
<div class="editEventBackground">
<div class="btn-group pull-right editEventBtnInner" rol="group">
<button type="button" class="btn btn-default editBtn" onclick="deleteEvent(event)">Delete Event</button>
<button type="button" class="btn btn-default editBtn" onclick="saveEvent(event)">Save</button>
<button type="button" class="btn btn-default editBtn" onclick="cancelEditEvent(event)">Cancel</button>
</div>
</div>
</div>
</div>
</template>
<div class="main-container">
<div class="button-container">
<div class="flex0">
<div id="commandPanel" class="btn-group" role="group">
<button id="dayView" type="button" class="btn btn-default">Day</button>
<button id="weekView" type="button" class="btn btn-default">Week</button>
<button id="monthView" type="button" class="btn btn-default active">Month</button>
</div>
</div>
<div class="flex1">
<div id="title">June 2018</div>
</div>
<div class="flex0">
<div class="btn-group" role="group">
<div class="btn btn-default app-prev">
<i class="demo-icon icon-left-big"></i>
</div>
<div class="btn btn-default app-next">
<i class="demo-icon icon-right-big"></i>
</div>
</div>
</div>
</div>
<div id="grid" class="grid"></div>
</div>
<script src="data.js" type="text/javascript"></script>
<script src="app.js" type="text/javascript"></script>
</body>
</html>
var editData;
var cols = [
{
id: 'topic',
dataField: 'topic',
},
{
id: 'start',
dataField: 'start',
dataType: 'date',
format: 'HH:mm',
},
{
id: 'end',
dataField: 'end',
dataType: 'date',
format: 'HH:mm',
},
{
id: 'speaker',
dataField: 'speaker',
},
];
var monthEventTemplate =
'\n<div class="event-container">\n <div class="event-title">\n <span class="time">{{=it.start}}</span> <span class="topic">{{=it.topic}}</span>\n </div>\n<div>';
var dayEventTemplate = '<div class="event-content">{{=it.topic}}</div>';
var now = new Date(Date.now());
var startTime = new Date(now.getFullYear(), now.getMonth(), now.getDate(), 8, 0, 0);
var endTime = new Date(now.getFullYear(), now.getMonth(), now.getDate(), 23, 0, 0);
var calendar = new GC.DataViews.CalendarGrouping({
viewMode: 'Month',
daysEventStartField: 'start',
daysEventEndField: 'end',
startDate: startTime,
daysStartTime: startTime,
daysEndTime: endTime,
});
calendar.eventClick.addHandler(function (args) {
removeDialog();
var dialog = createEditEventDialog();
if (dialog) {
setTimeout(function () {
var popoverDialog = $('.popover-dialog');
if (popoverDialog.length > 0) {
popoverDialog.remove();
}
dataView.container.parentElement.appendChild(dialog);
if (!args.data) {
var start = new Date();
var end = new Date(
start.getFullYear(),
start.getMonth(),
start.getDate(),
start.getHours() + 2,
start.getMinutes(),
start.getSeconds()
);
args.data = {
topic: '',
start: start,
end: end,
};
}
editData = args.data;
var excelFormatter = new GC.DataViews.GeneralFormatter('hh:mm:ss');
$('#editDialog #eventTitleContent')[0].value = editData.topic;
$('#editDialog #datetimepicker1')[0].value = excelFormatter.format(editData.start);
$('#editDialog #datetimepicker2')[0].value = excelFormatter.format(editData.end);
}, 100);
}
});
var dataView = new GC.DataViews.DataView(
document.getElementById('grid'),
data,
cols,
new GC.DataViews.GridLayout({
grouping: {
field: 'start',
converter: function converter(field) {
return field.toDateString();
},
},
rowTemplate: monthEventTemplate,
groupStrategy: calendar,
})
);
updateTitle();
function previousMonth() {
var options = calendar.options;
var currentDate = options.startDate;
if (options.viewMode === 'Month') {
currentDate = getMonth(currentDate, -1);
} else if (options.viewMode === 'Week') {
currentDate = getDay(currentDate, -7);
} else {
currentDate = getDay(currentDate, -1);
}
calendar.options.startDate = currentDate;
updateTitle();
dataView.invalidate();
}
function nextMonth() {
var options = calendar.options;
var currentDate = options.startDate;
if (options.viewMode === 'Month') {
currentDate = getMonth(currentDate, 1);
} else if (options.viewMode === 'Week') {
currentDate = getDay(currentDate, 7);
} else {
currentDate = getDay(currentDate, 1);
}
calendar.options.startDate = currentDate;
updateTitle();
dataView.invalidate();
}
function changeToDayView() {
$('#commandPanel .btn').removeClass('active');
$('#dayView').addClass('active');
var options = dataView.options;
options.rowHeight = 50;
options.rowTemplate = dayEventTemplate;
calendar.options.viewMode = 'Day';
dataView.invalidate();
updateTitle();
}
function changeToWeekView() {
$('#commandPanel .btn').removeClass('active');
$('#weekView').addClass('active');
var options = dataView.options;
options.rowHeight = 50;
options.rowTemplate = dayEventTemplate;
calendar.options.viewMode = 'Week';
dataView.invalidate();
updateTitle();
}
function changeToMonthView() {
$('#commandPanel .btn').removeClass('active');
$('#monthView').addClass('active');
var options = dataView.options;
options.rowHeight = 24;
options.rowTemplate = monthEventTemplate;
calendar.options.viewMode = 'Month';
dataView.invalidate();
updateTitle();
}
function createEditEventDialog() {
var eventDialog = document.getElementById('editDialogTemplate').innerHTML;
var div = document.createElement('div');
div.innerHTML = eventDialog;
var dialog = div.children[0];
dialog.id = 'editDialog';
return dialog;
}
window.saveEvent = function saveEvent() {
if (editData) {
var oldStart = editData.start;
var oldEnd = editData.end;
editData.topic = $('#editDialog #eventTitleContent')[0].value;
var newStartValue = $('#editDialog #datetimepicker1')[0].value;
var newEndValue = $('#editDialog #datetimepicker2')[0].value;
if (newStartValue && newEndValue) {
var newStart = newStartValue.split(':');
var newEnd = newEndValue.split(':');
while (newStart.length < 3) {
newStart.push('0');
}
while (newEnd.length < 3) {
newEnd.push('0');
}
editData.start = new Date(
oldStart.getFullYear(),
oldStart.getMonth(),
oldStart.getDate(),
parseInt(newStart[0], 10),
parseInt(newStart[1], 10),
parseInt(newStart[2], 10)
);
editData.end = new Date(
oldEnd.getFullYear(),
oldEnd.getMonth(),
oldEnd.getDate(),
parseInt(newEnd[0], 10),
parseInt(newEnd[1], 10),
parseInt(newEnd[2], 10)
);
dataView.invalidate();
}
removeDialog();
}
};
window.deleteEvent = function deleteEvent(e) {
dataView.data.removeDataItems(editData.sourceIndex, 1);
removeDialog();
};
window.cancelEditEvent = function cancelEditEvent() {
removeDialog();
};
window.removeDialog = function removeDialog() {
var dialog = document.getElementById('editDialog');
if (dialog) {
dialog.parentNode.removeChild(dialog);
}
};
function getDay(currentDate, daysCount) {
var date = new Date(currentDate);
var timeSpan = 1000 * 60 * 60 * 24 * (daysCount || 1);
date.setTime(date.getTime() + timeSpan);
return date;
}
function getMonth(currentDate, monthCount) {
var year = currentDate.getFullYear();
var month = currentDate.getMonth() + monthCount;
var day = currentDate.getDate();
if (month === 12) {
month = 0;
year += 1;
} else if (month === -1) {
month = 11;
year -= 1;
}
return new Date(year, month, day, 0, 0, 0);
}
function formatDate(format, date) {
var formatter = new GC.DataViews.GeneralFormatter(format);
return formatter.format(date);
}
function getMonday(date) {
date = new Date(date);
date.setDate(date.getDate() - date.getDay());
return date;
}
function formatTitle(options) {
var date = options.startDate;
if (options.viewMode === 'Month') {
return formatDate('mmmm yyyy', date);
} else if (options.viewMode === 'Week') {
var d1 = getMonday(date);
var d2 = getDay(d1, 6);
if (d1.getFullYear() !== d2.getFullYear()) {
return formatDate('mmmm d, yyyy', d1) + formatDate(' - mmmm d, yyyy', d2);
}
return formatDate('mmmm d', d1) + formatDate(' - mmmm d, yyyy', d2);
} else {
return formatDate('mmmm d, yyyy', date);
}
}
function updateTitle() {
var title = document.getElementById('title');
title.innerText = formatTitle(calendar.options);
}
$('#dayView').click(changeToDayView);
$('#weekView').click(changeToWeekView);
$('#monthView').click(changeToMonthView);
$('.app-prev').click(previousMonth);
$('.app-next').click(nextMonth);
// timetable
var data = [
{
topic: 'Leaving',
start: 'June 15,2018 9:00:00',
end: 'June 15,2018 20:00:00',
speaker: '',
},
{
topic: 'Introductions, Name Game. Hopes Fears & Expectations',
start: 'June 4,2018 8:00:00',
end: 'June 4,2018 11:30:00',
speaker: 'Steve',
},
{
topic: 'Permaculture Ethics & Philosophies',
start: 'June 4,2018 13:30:00',
end: 'June 4,2018 16:00:00',
speaker: 'Steve',
},
{
topic: 'DINNER',
start: 'June 4,2018 17:00:00',
end: 'June 4,2018 20:00:00',
speaker: '',
},
{
topic: 'Soil Erosion&Conservation',
start: 'June 6,2018 9:00:00',
end: 'June 6,2018 15:30:00',
speaker: 'Steve',
},
{
topic: 'Soil Practical Gardening',
start: 'June 6,2018 17:30:00',
end: 'June 6,2018 19:30:00',
speaker: 'Tony',
},
{
topic: 'Micro Climate',
start: 'June 8,2018 13:00:00',
end: 'June 8,2018 17:30:00',
speaker: 'Fiona',
},
{
topic: 'Earthworks',
start: 'June 11,2018 9:45:00',
end: 'June 11,2018 13:15:00',
speaker: 'Steve',
},
{
topic: 'Herb Introduction',
start: 'June 11,2018 14:00:00',
end: 'June 11,2018 15:30:00',
speaker: 'Fiona',
},
{
topic: 'TEA BREAK',
start: 'June 11,2018 17:30:00',
end: 'June 11,2018 19:00:00',
speaker: '',
},
{
topic: 'Organic intelligent algorithm introduction',
start: 'June 14,2018 11:00:00',
end: 'June 14,2018 19:00:00',
speaker: '',
},
{
topic: 'Built Environment Buildings',
start: 'June 1,2018 9:00:00',
end: 'June 1,2018 10:30:00',
speaker: 'Steve',
},
{
topic: 'Short introduction',
start: 'June 1,2018 13:30:00',
end: 'June 1,2018 15:00:00',
speaker: 'Steve',
},
{
topic: 'Design Groups Site Introduction Customer Brief',
start: 'June 1,2018 15:30:00',
end: 'June 1,2018 16:30:00',
speaker: 'Tony',
},
{
topic: 'DINNER',
start: 'June 1,2018 17:00:00',
end: 'June 1,2018 19:00:00',
speaker: '',
},
{
topic: 'Film: Global Gardener 4',
start: 'June 1,2018 19:00:00',
end: 'June 1,2018 21:00:00',
speaker: '',
},
];
function randomSeries(min, max, count) {
var set = new Set();
var result = [];
while (result.length < count) {
var val = _.random(min, max);
if (set.has(val)) {
continue;
}
set.add(val);
result.push(val);
if (set.size >= max - min + 1) {
set.clear();
}
}
return result;
} // generate start and end dates
var now = new Date(Date.now());
var year = now.getFullYear();
var month = now.getMonth();
var wd = now.getDay();
var days = randomSeries(-wd - 2, 9 - wd, data.length);
var minutes = [0, 30];
function generateStart(idx) {
var day = now.getDate() + days[idx];
var hour = _.random(8, 16);
var minute = minutes[_.random(0, 1)];
return new Date(year, month, day, hour, minute, 0);
}
function overlapFn(events) {
return function (startDate) {
var start = startDate.getTime();
return (
_.findIndex(events, function (event) {
return start >= event.start.getTime() && start <= event.end.getTime();
}) >= 0
);
};
}
data.forEach(function (event, idx) {
var isOverlap = overlapFn(data.slice(0, idx));
var start = generateStart(idx);
while (isOverlap(start)) {
start = generateStart(idx);
}
var duration = [60, 90, 120, 150, 180][_.random(0, 1)] * 60 * 1000;
event.start = start;
event.end = new Date(start.getTime() + duration);
});
@charset "UTF-8";
@font-face {
font-family: "spreadview-demo-icon";
src: url(data:application/font-woff;base64,d09GRgABAAAAABFcAA8AAAAAHdwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABWAAAADMAAABCsP6z7U9TLzIAAAGMAAAAQwAAAFY+IUkyY21hcAAAAdAAAAB2AAAB7glP7Q1jdnQgAAACSAAAABMAAAAgBtX/AmZwZ20AAAJcAAAFkAAAC3CKkZBZZ2FzcAAAB+wAAAAIAAAACAAAABBnbHlmAAAH9AAABmYAAAoULpqylGhlYWQAAA5cAAAAMAAAADYJoqfYaGhlYQAADowAAAAdAAAAJAc9A11obXR4AAAOrAAAABgAAAAsJ50AAGxvY2EAAA7EAAAAGAAAABgNMA9MbWF4cAAADtwAAAAgAAAAIAEhDDZuYW1lAAAO/AAAAXcAAALNzJ0cHnBvc3QAABB0AAAAbAAAAJC8t9mhcHJlcAAAEOAAAAB6AAAAhuVBK7x4nGNgZGBg4GKQY9BhYHRx8wlh4GBgYYAAkAxjTmZ6IlAMygPKsYBpDiBmg4gCAIojA08AeJxjYGSexTiBgZWBgamKaQ8DA0MPhGZ8wGDIyAQUZWBlZsAKAtJcUxgcXjC84GQO+p/FEMUcxDAdKMwIkgMA8cgL0QB4nO2R0Q3CQAxD39FQ6Kmj8MlAfDELo2aL1kk9BpGepVi5+7CBO7CIlwgYXwY1H7mj/YXZfvDumyg/t+OQUqo9Wm+6Df248uDJ1u9W/rO3/rzNyu2ikzRKjzTVSJrKNk21lUYpk0Z5k0bJk0YdqKkL5gl3XxtNAAB4nGNgQAMSEMgc9D8ThAESZgPbAHicrVZpd9NGFB15SZyELCULLWphxMRpsEYmbMGACUGyYyBdnK2VoIsUO+m+8Ynf4F/zZNpz6Dd+Wu8bLySQtOdwmpOjd+fN1czbZRJaktgL65GUmy/F1NYmjew8CemGTctRfCg7eyFlisnfBVEQrZbatx2HREQiULWusEQQ+x5ZmmR86FFGy7akV03KLT3pLlvjQb1V334aOsqxO6GkZjN0aD2yJVUYVaJIpj1S0qZlqPorSSu8v8LMV81QwohOImm8GcbQSN4bZ7TKaDW24yiKbLLcKFIkmuFBFHmU1RLn5IoJDMoHzZDyyqcR5cP8iKzYo5xWsEu20/y+L3mndzk/sV9vUbbkQB/Ijuzg7HQlX4RbW2HctJPtKFQRdtd3QmzZ7FT/Zo/ymkYDtysyvdCMYKl8hRArP6HM/iFZLZxP+ZJHo1qykRNB62VO7Es+gdbjiClxzRhZ0N3RCRHU/ZIzDPaYPh788d4plgsTAngcy3pHJZwIEylhczRJ2jByYCVliyqp9a6YOOV1WsRbwn7t2tGXzmjjUHdiPFsPHVs5UcnxaFKnmUyd2knNoykNopR0JnjMrwMoP6JJXm1jNYmVR9M4ZsaERCICLdxLU0EsO7GkKQTNoxm9uRumuXYtWqTJA/Xco/f05la4udNT2g70s0Z/VqdiOtgL0+lp5C/xadrlIkXp+ukZfkziQdYCMpEtNsOUgwdv/Q7Sy9eWHIXXBtju7fMrqH3WRPCkAfsb0B5P1SkJTIWYVYhWQGKta1mWydWsFqnI1HdDmla+rNMEinIcF8e+jHH9XzMzlpgSvt+J07MjLj1z7UsI0xx8m3U9mtepxXIBcWZ5TqdZlu/rNMfyA53mWZ7X6QhLW6ejLD/UaYHlRzodY3lBC5p038GQizDkAg6QMISlA0NYXoIhLBUMYbkIQ1gWYQjLJRjC8mMYwnIZhrC8rGXV1FNJ49qZWAZsQmBijh65zEXlaiq5VEK7aFRqQ54SbpVUFM+qf2WgXjzyhjmwFkiXyJpfMc6Vj0bl+NYVLW8aO1fAsepvH472OfFS1ouFPwX/1dZUJb1izcOTq/Abhp5sJ6o2qXh0TZfPVT26/l9UVFgL9BtIhVgoyrJscGcihI86nYZqoJVDzGzMPLTrdcuan8P9NzFCFlD9+DcUGgvcg05ZSVnt4KzV19uy3DuDcjgTLEkxN/P6VvgiI7PSfpFZyp6PfB5wBYxKZdhqA60VvNknMQ+Z3iTPBHFbUTZI2tjOBIkNHPOAefOdBCZh6qoN5E7hhg34BWFuwXknXKJ6oyyH7kXs8yik/Fun4kT2qGiMwLPZG2Gv70LKb3EMJDT5pX4MVBWhqRg1FdA0Um6oBl/G2bptQsYO9CMqdsOyrOLDxxb3lZJtGYR8pIjVo6Of1l6iTqrcfmYUl++dvgXBIDUxf3vfdHGQyrtayTJHbQNTtxqVU9eaQ+NVh+rmUfW94+wTOWuabronHnpf06rbwcVcLLD2bQ7SUiYX1PVhhQ2iy8WlUOplNEnvuAcYFhjQ71CKjf+r+th8nitVhdFxJN9O1LfR52AM/A/Yf0f1A9D3Y+hyDS7P95oTn2704WyZrqIX66foNzBrrblZugbc0HQD4iFHrY64yg18pwZxeqS5HOkh4GPdFeIBwCaAxeAT3bWM5lMAo/mMOT7A58xh0GQOgy3mMNhmzhrADnMY7DKHwR5zGHzBnHWAL5nDIGQOg4g5DJ4wJwB4yhwGXzGHwdfMYfANc+4DfMscBjFzGCTMYbCv6dYwzC1e0F2gtkFVoANTT1jcw+JQU2XI/o4Xhv29Qcz+wSCm/qjp9pD6Ey8M9WeDmPqLQUz9VdOdIfU3Xhjq7wYx9Q+DmPpMvxjLZQa/jHyXCgeUXWw+5++J9w/bxUC5AAEAAf//AA94nKVVWW8b1xU+597ZOByumoWyyDE3cWxSkFyuiqxSlBfQkukFtpDQSaTQjqy2kG3JDeCg6PagwLXRJgKyFKhbBAisxwat+tKXAH1on7oAbX5CHwIZRZGnPrSIxj2XYhU7ibqgQ86957vnzMy55zvnXAgAPP473+FBiMBhmIAZuAAvwRp8FzbhQqsTCzE1ajCFq0ovEmA8rDGGnPWCMkMAXBAzQleXGCB03vj+3Y3vfPPOK7dWV15eeuHZy+fP1gZXJS6nSqOWqai5bMGrVetOpWzHCHsD3CCMn9ELXMI9fBz38BfZfxn/vb3QC/uhgV7gvt5N279wXKTRTj8h4vV94Lj+Tw7S4MqnDz5h9bTiiZc/uGETtG7Qa1xUVsXkrAoL/w9PaFh+VdiLwf/9/2qE2v46AChfyO1065kgqjr2OQ0g17DPqIx9QmkiPiUUdH6GQuO/pTAz0GcOoGSgb2T2KMkNcCVzMCXst2l791EfMcdxdxsH6/Ap9P8F/el4UoAe3+NX2F8hBflWBhhna7SI68AB+AJwDl0SoFNw7JwkJ0rY351jmxFUsh4Wqg2slw+jwLRXfiWf8l/dsqyiddzy3zZNvGFN2UXL2sL7qTwutd3iljltlgYKXBWWU/bWEdj3pUa+uH1fOONrYnUdqCDZAlCZdoGY7dijBbPvi6mSExPkxAxmBjWT8QSqlx20ec3037GnrKJtP/RfTeXzKbz/0LaL/Q+bOOWawsOiNW09LLrkGW5Z0wQt/x2z78v3KM9qMAReK69TBmE7gHA6SM6cIq8QFoTLXRGsTr7AZLtkVZtypRbAWDYsHztzp/f2xZP4iv/6yrUH89fKY9/Y/PObK+VD0t/8H/ivo8Hi2VPXftj/ztf4Dvs1FCDZGh6ht2E7hHBKvJd2Dyv5bI7JFu01jLmsp6j0o9Qq1Au0yxlsshkcR6/aZJWyi3zn7kf3vOKtt0byepgziXFDCpmqGVUj3WW8+NoHy/c+uotLV7d60tWCJqGhI9MkHpHDtpZMDhXLby7Mvdab7G0J9h9v8+f5JdCgCbfgXGt+brbBuYxtkClJZH4TdACmQ48smKyxJXpGlbjaAwkUSXmRNhLoQiBg4NzN1ZXl0UozWf/SYasUpJJrVMdRMe0mYrXg5ap1j6YwU5UIhhnd6OVitB3Jsam+alWviVWvXiObJjZM1bb27kEVFsRYi4larDfqjSZr1EUoyIBqd9NO2vRnG2PJ39Qx2wiHTSfkhoLhhG4bph6Pq3Y4aSTZnbmTqyxq6ik9EE+0R2QLM73zZ+pfPT1rvJcqFlM/Mp9JJ0OGnbCTE/NHRq5NPbscMVniUIKZeDFVxPTX040qRk7MJ0KFWDiaDgzpBvo/ZoqiKezoYiQaKB6JJ71QXsOyVT4aN0sFw5gsnX/+kOMUU3jdLYbmim74RMe28udnK5MityiOgoNz7DF1PROGIQ93W1TBTE7ZYYo0G6YCAS6am9Q++/P4xW7LI27ktb0iJtVaP09fVhAlCS/RhNJzIKF0dqRV+LwlrH3e8EorDpBJJ5xoJKCRG4qpUi46DU+1KhZWc1kqQMuslKkJeA7makhtwGv0G8LvyhuVM/iSIUv+n6SQLOEEd3f8Yzv8nLm4s2getzeIoY3KdJsphuR/KNGI49LtHX/iET5IWYuPXrSsDRsGPX+bx/d7/nE4CV+B5dbV504zRTuaGY4FUKHG0JY5I0FBuCkxBqoC6iqEIaCFA71IiGmGzhTUlCVQg0F1AVQ12IWgGuxcX7669MKVy5cudObaszNm3iyIKxelRMXYXpbt5VfZdv4DHoplYqaL1PYptyseJbdCARM2scGhEMv967BuUDZTih5Gcca4upbX9P6w+an4hq7uiap+xjc0jeEfmab59/8xIsnbioR/0bV6ddQ/NlrFmrD7qRcYo+NjTPPe13T8pf8rsYizYjxA9pdZbPdjKgXdZNdn6aSUL9MXdz8eP3VinA31nVi0kuiai3qfh3f5Jk+JSocgRCknXZhvtUUX4wiiA1BjoE4gg6TI0pJuaFxRVWWhLyhqNxigIlc78ZibSo7YVmw4PhyLx8QVDcnJEmZqmf27Wjazo2U7jOOs7gjANz/Z4N/2t3c/ZON4QcifbKyvY8LOMvdYmuU/WF9n76/72+v+z9b8b03evp0dy2N2PN2YvA3/BLk0ptwAAHicY2BkYGAA4gc3EqbH89t8ZeBmfgEUYbjsu0kGQf/PZH7BHATkcjAwgUQBYW4L1XicY2BkYGAO+p8FJF8wMPz/DySBIiiAGwCH1AWgAAAAeJxjfsHAwAzDkVCMzhcE4gUMDACy5wa/AAAAAADuAZYB3AIiAlYCogNkA+gErAUKAAEAAAALAJAACQAAAAAAAgAkADQAcwAAAHULcAAAAAB4nHWQy07CQBSG/5GLCokaTdw6KwMxlksiCxISEgxsdEMMW1NKaUtKh0wHEl7Dd/BhfAmfxZ92MAZim+l855szZ04HwDW+IZA/Txw5C5wxyvkEp+hZLtA/Wy6SXyyXUMWb5TL9u+UKHhBYruIGH6wgiueMFvi0LHAlLi2f4ELcWS7QP1ouknuWS7gVr5bL9J7lCiYitVzFvfgaqNVWR0FoZG1Ql+1mqyOnW6moosSNpbs2odKp7Mu5Sowfx8rx1HLPYz9Yx67eh/t54us0UolsOc29GvmJr13jz3bV003QNmYu51ot5dBmyJVWC98zTmjMqtto/D0PAyissIVGxKsKYSBRo61zbqOJFjqkKTMkM/OsCAlcxDQu1twRZisp4z7HnFFC6zMjJjvw+F0e+TEp4P6YVfTR6mE8Ie3OiDIv2ZfD7g6zRqQky3QzO/vtPcWGp7VpDXftutRZVxLDgxqS97FbW9B49E52K4a2iwbff/7vB+NphE8AeJxtxkEOgyAQBdD5tIpIr8KhkIwOCVgC46K3b9JufatHhv5Wuudh8MATE2ZYLHBY4fEio2JVQslDl8K7hi0frudDfpuGxM42vWvlU53KVbcRrjY3PlMuXnscErg2/fjYNafCIRYl+gJfpB7ZeJxj8N7BcCIoYiMjY1/kBsadHAwcDMkFGxlYnTYxMDJogRibuZgYOSAsPgYwi81pF9MBoDQnkM3utIvBAcJmZnDZqMLYERixwaEjYiNzistGNRBvF0cDAyOLQ0dySARISSQQbOZhYuTR2sH4v3UDS+9GJgYXAAx2I/QAAA==) format("woff");
}
.demo-icon {
-moz-osx-font-smoothing: grayscale;
-webkit-font-smoothing: antialiased;
display: inline-block;
font-family: "spreadview-demo-icon";
font-style: normal;
font-variant: normal;
text-align: center;
text-transform: none;
}
.icon-left-big:before {
content: "";
}
.icon-right-big:before {
content: "";
}
.main-container {
display: flex;
flex-direction: column;
width: 100%;
height: 100%;
}
.button-container {
display: flex;
align-items: center;
justify-content: space-between;
overflow: hidden;
flex-grow: 0;
flex-shrink: 0;
padding: 5px;
}
.button-container .btn {
display: flex;
align-items: center;
justify-content: center;
height: 32px;
}
.grid {
width: 100%;
height: calc(100% - 32px);
min-height: 605px;
flex-grow: 1;
flex-shrink: 1;
}
.flex0 {
flex-grow: 0;
flex-shrink: 0;
}
.flex1 {
flex-grow: 1;
flex-shrink: 1;
}
#title {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
font-family: Helvetica, sans-serif;
font-size: 16px;
color: #333;
}
.calendar-grouping .day-event,
.calendar-grouping .month-event {
font-family: Helvetica, sans-serif;
font-size: 10px;
box-sizing: border-box;
cursor: pointer;
}
.calendar-grouping .day-event {
margin: 2px;
padding: 8px;
display: flex;
align-items: center;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
min-width: 0;
}
.calendar-grouping .day-event .event-content {
width: 100%;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
.calendar-grouping .event-container {
padding: 0 5px;
}
.calendar-grouping .event-container .event-title {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.calendar-grouping .event-container .event-title .time {
color: white;
background-color: #5d89b7;
border-radius: 5px;
padding: 1px 4px;
}
.calendar-grouping .event-container .event-title .topic {
padding-left: 5px;
}
.calendar-grouping .popover-dialog {
font-family: Helvetica, sans-serif;
font-size: 10px;
}
.gc-editing-close {
color: #5d89b7;
}
.gc-editing-close:hover {
color: #80a3c7;
}
.editEventDialog {
background-color: #fff;
border-radius: 4px;
box-shadow: 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24);
position: absolute;
width: 480px;
}
.editEventDialog .editEventBackground {
border-bottom: solid 1px #f1f1f1;
overflow: hidden;
}
.editEventDialog .editEventBackground .editEventHeaderInner {
font-family: helvetica, arial, verdana, sans-serif;
font-size: 15px;
font-weight: 300;
margin: 10px;
}
.editEventDialog .editEventBackground .editEventHeaderInner .header {
display: inline-block;
}
.editEventDialog .editEventBackground .editEventBtnInner {
margin: 1em 0.4em;
}
.editEventDialog .editEventBackground .btn-group .editBtn {
background-color: #5d89b7;
border: 0;
border-radius: 2px;
color: #fff;
margin-right: 0.4em;
padding: 5px;
}
.editEventDialog .editEventBackground .btn-group .editBtn:hover {
background: #80a3c7;
}
.editEventDialog .editEventContent {
margin: 1em;
}
.editEventDialog .editEventContent .contentItem {
display: flex;
align-items: center;
justify-content: stretch;
margin: 1em 0;
}
.editEventDialog .editEventContent .contentItem label {
margin: 0 1em;
}
.editEventDialog .editEventContent .contentItem .title {
color: #666666;
font-weight: inherit;
flex-grow: 0;
flex-shrink: 0;
}
.editEventDialog .editEventContent .contentItem .title.fixed {
width: 60px;
}
.editEventDialog .editEventContent .contentItem .input-container {
flex-grow: 1;
flex-shrink: 0;
}
.editEventDialog .editEventContent .contentItem .input-container input {
width: 100%;
}
@media only screen and (max-width: 768px) {
.editEventDialog {
width: 350px;
}
}
.backdrop {
position: fixed;
top: 0;
left: 0;
height: 100%;
width: 100%;
z-index: 0;
background-color: rgba(255, 255, 255, 0.15);
display: flex;
align-items: center;
justify-content: center;
}
/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["DataViews/Calendar/Calendar/purejs/styles.css","DataViews/Calendar/Calendar/purejs/styles.scss"],"names":[],"mappings":"AAAA,gBAAgB;ACEhB;EACE,mCAAA;EACA,m2LAAA;ADAF;ACIA;EACE,kCAAA;EACA,mCAAA;EACA,qBAAA;EACA,mCAAA;EACA,kBAAA;EACA,oBAAA;EACA,kBAAA;EACA,oBAAA;ADFF;;ACKA;EACE,YAAA;ADFF;;ACKA;EACE,YAAA;ADFF;;ACKA;EACE,aAAA;EACA,sBAAA;EACA,WAAA;EACA,YAAA;ADFF;;ACKA;EACE,aAAA;EACA,mBAAA;EACA,8BAAA;EACA,gBAAA;EACA,YAAA;EACA,cAAA;EACA,YAAA;ADFF;ACIE;EACE,aAAA;EACA,mBAAA;EACA,uBAAA;EACA,YAAA;ADFJ;;ACMA;EACE,WAAA;EACA,yBAAA;EACA,iBAAA;EACA,YAAA;EACA,cAAA;ADHF;;ACMA;EACE,YAAA;EACA,cAAA;ADHF;;ACMA;EACE,YAAA;EACA,cAAA;ADHF;;ACMA;EACE,aAAA;EACA,mBAAA;EACA,uBAAA;EACA,WAAA;EACA,kCAAA;EACA,eAAA;EACA,WAAA;ADHF;;ACOE;;EAEE,kCAAA;EACA,eAAA;EACA,sBAAA;EACA,eAAA;ADJJ;ACOE;EACE,WAAA;EACA,YAAA;EACA,aAAA;EACA,mBAAA;EACA,gBAAA;EACA,mBAAA;EACA,uBAAA;EACA,YAAA;ADLJ;ACOI;EACE,WAAA;EACA,gBAAA;EACA,mBAAA;EACA,uBAAA;ADLN;ACSE;EACE,cAAA;ADPJ;ACSI;EACE,gBAAA;EACA,uBAAA;EACA,mBAAA;ADPN;ACSM;EACE,YAAA;EACA,yBApHY;EAqHZ,kBAAA;EACA,gBAAA;ADPR;ACUM;EACE,iBAAA;ADRR;ACaE;EACE,kCAAA;EACA,eAAA;ADXJ;;ACeA;EACE,cAtIkB;AD0HpB;ACcE;EACE,cAAA;ADZJ;;ACgBA;EACE,sBAAA;EACA,kBAAA;EACA,sEAAA;EACA,kBAAA;EACA,YAAA;ADbF;ACeE;EACE,gCAAA;EACA,gBAAA;ADbJ;ACeI;EACE,kDAAA;EACA,eAAA;EACA,gBAAA;EACA,YAAA;ADbN;ACeM;EACE,qBAAA;ADbR;ACiBI;EACE,iBAAA;ADfN;ACmBM;EACE,yBAzKY;EA0KZ,SAAA;EACA,kBAAA;EACA,WAAA;EACA,mBAAA;EACA,YAAA;ADjBR;ACmBQ;EACE,mBAAA;ADjBV;ACuBE;EACE,WAAA;ADrBJ;ACuBI;EACE,aAAA;EACA,mBAAA;EACA,wBAAA;EACA,aAAA;ADrBN;ACuBM;EACE,aAAA;ADrBR;ACwBM;EACE,cAAA;EACA,oBAAA;EACA,YAAA;EACA,cAAA;ADtBR;ACwBQ;EACE,WAAA;ADtBV;AC0BM;EACE,YAAA;EACA,cAAA;ADxBR;AC0BQ;EACE,WAAA;ADxBV;;AC+BA;EACE;IACE,YAAA;ED5BF;AACF;AC+BA;EACE,eAAA;EACA,MAAA;EACA,OAAA;EACA,YAAA;EACA,WAAA;EACA,UAAA;EACA,2CAAA;EACA,aAAA;EACA,mBAAA;EACA,uBAAA;AD7BF","file":"DataViews/Calendar/Calendar/purejs/styles.css","sourcesContent":["@charset \"UTF-8\";\n@font-face {\n  font-family: \"spreadview-demo-icon\";\n  src: url(data:application/font-woff;base64,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) format(\"woff\");\n}\n.demo-icon {\n  -moz-osx-font-smoothing: grayscale;\n  -webkit-font-smoothing: antialiased;\n  display: inline-block;\n  font-family: \"spreadview-demo-icon\";\n  font-style: normal;\n  font-variant: normal;\n  text-align: center;\n  text-transform: none;\n}\n\n.icon-left-big:before {\n  content: \"\";\n}\n\n.icon-right-big:before {\n  content: \"\";\n}\n\n.main-container {\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  height: 100%;\n}\n\n.button-container {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  overflow: hidden;\n  flex-grow: 0;\n  flex-shrink: 0;\n  padding: 5px;\n}\n.button-container .btn {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 32px;\n}\n\n.grid {\n  width: 100%;\n  height: calc(100% - 32px);\n  min-height: 605px;\n  flex-grow: 1;\n  flex-shrink: 1;\n}\n\n.flex0 {\n  flex-grow: 0;\n  flex-shrink: 0;\n}\n\n.flex1 {\n  flex-grow: 1;\n  flex-shrink: 1;\n}\n\n#title {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  font-family: Helvetica, sans-serif;\n  font-size: 16px;\n  color: #333;\n}\n\n.calendar-grouping .day-event,\n.calendar-grouping .month-event {\n  font-family: Helvetica, sans-serif;\n  font-size: 10px;\n  box-sizing: border-box;\n  cursor: pointer;\n}\n.calendar-grouping .day-event {\n  margin: 2px;\n  padding: 8px;\n  display: flex;\n  align-items: center;\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  min-width: 0;\n}\n.calendar-grouping .day-event .event-content {\n  width: 100%;\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n}\n.calendar-grouping .event-container {\n  padding: 0 5px;\n}\n.calendar-grouping .event-container .event-title {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n.calendar-grouping .event-container .event-title .time {\n  color: white;\n  background-color: #5d89b7;\n  border-radius: 5px;\n  padding: 1px 4px;\n}\n.calendar-grouping .event-container .event-title .topic {\n  padding-left: 5px;\n}\n.calendar-grouping .popover-dialog {\n  font-family: Helvetica, sans-serif;\n  font-size: 10px;\n}\n\n.gc-editing-close {\n  color: #5d89b7;\n}\n.gc-editing-close:hover {\n  color: #80a3c7;\n}\n\n.editEventDialog {\n  background-color: #fff;\n  border-radius: 4px;\n  box-shadow: 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24);\n  position: absolute;\n  width: 480px;\n}\n.editEventDialog .editEventBackground {\n  border-bottom: solid 1px #f1f1f1;\n  overflow: hidden;\n}\n.editEventDialog .editEventBackground .editEventHeaderInner {\n  font-family: helvetica, arial, verdana, sans-serif;\n  font-size: 15px;\n  font-weight: 300;\n  margin: 10px;\n}\n.editEventDialog .editEventBackground .editEventHeaderInner .header {\n  display: inline-block;\n}\n.editEventDialog .editEventBackground .editEventBtnInner {\n  margin: 1em 0.4em;\n}\n.editEventDialog .editEventBackground .btn-group .editBtn {\n  background-color: #5d89b7;\n  border: 0;\n  border-radius: 2px;\n  color: #fff;\n  margin-right: 0.4em;\n  padding: 5px;\n}\n.editEventDialog .editEventBackground .btn-group .editBtn:hover {\n  background: #80a3c7;\n}\n.editEventDialog .editEventContent {\n  margin: 1em;\n}\n.editEventDialog .editEventContent .contentItem {\n  display: flex;\n  align-items: center;\n  justify-content: stretch;\n  margin: 1em 0;\n}\n.editEventDialog .editEventContent .contentItem label {\n  margin: 0 1em;\n}\n.editEventDialog .editEventContent .contentItem .title {\n  color: #666666;\n  font-weight: inherit;\n  flex-grow: 0;\n  flex-shrink: 0;\n}\n.editEventDialog .editEventContent .contentItem .title.fixed {\n  width: 60px;\n}\n.editEventDialog .editEventContent .contentItem .input-container {\n  flex-grow: 1;\n  flex-shrink: 0;\n}\n.editEventDialog .editEventContent .contentItem .input-container input {\n  width: 100%;\n}\n\n@media only screen and (max-width: 768px) {\n  .editEventDialog {\n    width: 350px;\n  }\n}\n.backdrop {\n  position: fixed;\n  top: 0;\n  left: 0;\n  height: 100%;\n  width: 100%;\n  z-index: 0;\n  background-color: rgba(255, 255, 255, 0.15);\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}","$header-color-dark: #5d89b7;\n\n@font-face {\n  font-family: 'spreadview-demo-icon';\n  src: url(data:application/font-woff;base64,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)\n    format('woff');\n}\n\n.demo-icon {\n  -moz-osx-font-smoothing: grayscale;\n  -webkit-font-smoothing: antialiased;\n  display: inline-block;\n  font-family: 'spreadview-demo-icon';\n  font-style: normal;\n  font-variant: normal;\n  text-align: center;\n  text-transform: none;\n}\n\n.icon-left-big:before {\n  content: '\\e802';\n}\n\n.icon-right-big:before {\n  content: '\\e803';\n}\n\n.main-container {\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  height: 100%;\n}\n\n.button-container {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  overflow: hidden;\n  flex-grow: 0;\n  flex-shrink: 0;\n  padding: 5px;\n\n  .btn {\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    height: 32px;\n  }\n}\n\n.grid {\n  width: 100%;\n  height: calc(100% - 32px);\n  min-height: 605px;\n  flex-grow: 1;\n  flex-shrink: 1;\n}\n\n.flex0 {\n  flex-grow: 0;\n  flex-shrink: 0;\n}\n\n.flex1 {\n  flex-grow: 1;\n  flex-shrink: 1;\n}\n\n#title {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  font-family: Helvetica, sans-serif;\n  font-size: 16px;\n  color: #333;\n}\n\n.calendar-grouping {\n  .day-event,\n  .month-event {\n    font-family: Helvetica, sans-serif;\n    font-size: 10px;\n    box-sizing: border-box;\n    cursor: pointer;\n  }\n\n  .day-event {\n    margin: 2px;\n    padding: 8px;\n    display: flex;\n    align-items: center;\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    min-width: 0;\n\n    .event-content {\n      width: 100%;\n      overflow: hidden;\n      white-space: nowrap;\n      text-overflow: ellipsis;\n    }\n  }\n\n  .event-container {\n    padding: 0 5px;\n\n    .event-title {\n      overflow: hidden;\n      text-overflow: ellipsis;\n      white-space: nowrap;\n\n      .time {\n        color: white;\n        background-color: $header-color-dark;\n        border-radius: 5px;\n        padding: 1px 4px;\n      }\n\n      .topic {\n        padding-left: 5px;\n      }\n    }\n  }\n\n  .popover-dialog {\n    font-family: Helvetica, sans-serif;\n    font-size: 10px;\n  }\n}\n\n.gc-editing-close {\n  color: $header-color-dark;\n\n  &:hover {\n    color: lighten($header-color-dark, 10%);\n  }\n}\n\n.editEventDialog {\n  background-color: #fff;\n  border-radius: 4px;\n  box-shadow: 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24);\n  position: absolute;\n  width: 480px;\n\n  .editEventBackground {\n    border-bottom: solid 1px #f1f1f1;\n    overflow: hidden;\n\n    .editEventHeaderInner {\n      font-family: helvetica, arial, verdana, sans-serif;\n      font-size: 15px;\n      font-weight: 300;\n      margin: 10px;\n\n      .header {\n        display: inline-block;\n      }\n    }\n\n    .editEventBtnInner {\n      margin: 1em 0.4em;\n    }\n\n    .btn-group {\n      .editBtn {\n        background-color: $header-color-dark;\n        border: 0;\n        border-radius: 2px;\n        color: #fff;\n        margin-right: 0.4em;\n        padding: 5px;\n\n        &:hover {\n          background: lighten($header-color-dark, 10%);\n        }\n      }\n    }\n  }\n\n  .editEventContent {\n    margin: 1em;\n\n    .contentItem {\n      display: flex;\n      align-items: center;\n      justify-content: stretch;\n      margin: 1em 0;\n\n      label {\n        margin: 0 1em;\n      }\n\n      .title {\n        color: rgb(102, 102, 102);\n        font-weight: inherit;\n        flex-grow: 0;\n        flex-shrink: 0;\n\n        &.fixed {\n          width: 60px;\n        }\n      }\n\n      .input-container {\n        flex-grow: 1;\n        flex-shrink: 0;\n\n        input {\n          width: 100%;\n        }\n      }\n    }\n  }\n}\n\n@media only screen and (max-width: 768px) {\n  .editEventDialog {\n    width: 350px;\n  }\n}\n\n.backdrop {\n  position: fixed;\n  top: 0;\n  left: 0;\n  height: 100%;\n  width: 100%;\n  z-index: 0;\n  background-color: rgba(255, 255, 255, 0.15);\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n"]} */