Calendar (Vue)

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 example uses Vue.

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/vue/" /> <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 | GrapeCity DataViewsJS Vue 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.grid.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="styles.css" rel="stylesheet" type="text/css" /> <!-- Google Tag Manager --> <script> (function (w, d, s, l, i) { w[l] = w[l] || []; w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' }); var f = d.getElementsByTagName(s)[0], j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src = 'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f); })(window, document, 'script', 'dataLayer', 'GTM-WT462SJ'); </script> <!-- End Google Tag Manager --> <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: 'vue', DVJS_LICENSE_KEY: 'GrapeCity-Internal-Use-Only,GrapeCity,E195393772372914#B0KV4Ny56Vr5Wb7w6buJWeGRWb4NXUnNXRlFWWXl6SoN5VzVkYslmQ95WTENkTllVQzd4QhpEejdDNJZlWOp6M7oERQNnWspkaaB5QMhnR7dmUkRnVJR4L5cHTKNkZZdDbRBzZIxmSSR6NrpVQaVUQrBlc6ImYysSd4UlUEZGbw2kMl9UOzQVMId6ZXtUN83CO5RzaZt4VY5kM5pkUGpUUUV7UExUeGpUdTV5dFJ4bPhTc8pGeXJHWrkzNlFzdUtWTr5UQDdVckdGbSVUWr2yMPNzctZVRxEEW9lEbsZHUKJnVaRXT5p6Z0tWMqJGVrtSTIZnaopGSWZXbVNjY0hzQB5We4dnUr3ER8MkI0IyUiwiIGZUNwEkN5MjI0ICSiwSM9ETO6czNygTM0IicfJye#4Xfd5nIZRVV9IiOiMkIsISM6ByUKN7dllmVhRXYEJiOi8kI1tlOiQmcQJCLiEDMzATOwAyMwgDMwIDMyIiOiQncDJCLiI7au26YukHdpNWZwFmcn9iKsAnau26YukHdpNWZwFmcn9iKs86Yu46bj9Se4l6YlBXYydmLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLt36YukHdpNWZwFmcn9iKiojIz5GRiwiI9RXaDVGchJ7RiojIh94QiwSZ5JHd0ICb6VkIsICNxkjM7MjM7czM9MTN9EjI0ICZJJye0ICRiwiI34zZN3yZGNlUnJDe5wkQPVlcBh7SppmUNBlU9dWS7J4ZMRES4MTZkRXTxM7Uq5GeQdHcyFHVup6dQd6ZDpEVrNDSh9kbNdzZrl4dwdPQ', SJS_LICENSE_KEY: '*.grapecity.com,E613631884219496#B0qRgJHWSJ7NyBlc8BjNMRHW7g7YldTZXFTQuFnW4hVOCplVSlVV09ERlhEZuVTVKlTazE4Q6VGSw2CdWZUWSVmbjVXbrxmWFVWR8ZzQro7U84WMGdlbuVHb73kS5kjUTN4NvFVdLdXWVR4Nox6Z7UUSysEcXJEMsN6bDN4TxMDVwVmWBRzKxhkTzAXTaJmdD3CRFJTd8R4R6M5RklWa6oUaLlXMwR4R8ZUdtRWVxUUaQh6VXNDdEhlZ7FHR6QXTPJTVvkWcyZnbSdHRtZHcYF6TKN4axYGcZNjTDF7TvFTTr24VqZjVHVjcLd7QkRmdNxkI0IyUiwiI5gDOEF4QGVjI0ICSiwiMzkTO9kTOyMTM0IicfJye35XX3JSSGljQiojIDJCLiITMuYHITpEIkFWZyB7UiojIOJyebpjIkJHUiwiI4MDMyEDMgkDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WagkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI6kDN9EjM4gDOxMjNzEjNiojIklkIs4XZzxWYmpjIyNHZisnOiwmbBJye0ICRiwiI34TQ72kNBV6YXpXdGxGWxdHcol4MyUGUHJVbQVHRx44Sw84YxRkS4QnZadDNmhWWxV5QxFlTlZEbBJ5N8gUNQlDb7J6Kl36YHVnb4NGN92UMFdlNORFU8VDSaFlQSVlS4EHTrA5Ohh', }, }; </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/js/license.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/systemjs/dist/system.js" type="text/javascript"></script> <script src="systemjs.config.js" type="text/javascript"></script> </head> <body class="theme-default"> <!-- Google Tag Manager (noscript) --> <noscript ><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-WT462SJ" height="0" width="0" style="display: none; visibility: hidden;" ></iframe ></noscript> <!-- End Google Tag Manager (noscript) --> <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 id="root"></div> <script type="text/javascript"> System.import('./app.vue'); </script> </body> </html>
<template> <div class="main-container"> <div class="button-container"> <div class="flex0"> <div id="commandPanel" class="btn-group" role="group"> <button type="button" class="btn btn-default" v-bind:class="{ active: view === 'Day' }" v-on:click="changeView('Day')" > {{ locale.day }} </button> <button type="button" class="btn btn-default" v-bind:class="{ active: view === 'Week' }" v-on:click="changeView('Week')" > {{ locale.week }} </button> <button type="button" class="btn btn-default" v-bind:class="{ active: view === 'Month' }" v-on:click="changeView('Month')" > {{ locale.month }} </button> </div> </div> <div class="flex1"> <div id="title">{{ title }}</div> </div> <div class="flex0"> <calnav :options="groupingOptions" /> </div> </div> <gc-dataview id="grid" class="grid" :data="data" :cols="cols" :layout="layout" :options="options" :groupingOptions="groupingOptions" /> </div> </template> <script> import Vue from 'vue'; import '@grapecity/dataviews.vue'; import { getControlByElement, GeneralFormatter } from '@grapecity/dataviews.core'; import { GridLayout } from '@grapecity/dataviews.grid'; import CalendarGrouping from '@grapecity/dataviews.calendar'; import { data } from './data'; import locale from './locale'; import { getDay } from './calnav.vue'; let editData; const 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' }, ]; const monthEventTemplate = ` <div class="event-container"> <div class="event-title"> <span class="time">{{=it.start}}</span> <span class="topic">{{=it.topic}}</span> </div> <div>`; const dayEventTemplate = '<div class="event-content">{{=it.topic}}</div>'; const now = new Date(Date.now()); const startTime = new Date(now.getFullYear(), now.getMonth(), now.getDate(), 8, 0, 0); const endTime = new Date(now.getFullYear(), now.getMonth(), now.getDate(), 23, 0, 0); function getDataView() { return getControlByElement(document.body); } const calendar = new CalendarGrouping({ viewMode: 'Month', daysEventStartField: 'start', daysEventEndField: 'end', startDate: startTime, daysStartTime: startTime, daysEndTime: endTime, }); calendar.eventClick.addHandler((args) => { removeDialog(); const dialog = createEditEventDialog(); if (dialog) { setTimeout(() => { const popoverDialog = $('.popover-dialog'); if (popoverDialog.length > 0) { popoverDialog.remove(); } const dataView = getDataView(); dataView.container.parentElement.appendChild(dialog); if (!args.data) { const start = new Date(); const end = new Date( start.getFullYear(), start.getMonth(), start.getDate(), start.getHours() + 2, start.getMinutes(), start.getSeconds() ); args.data = { topic: '', start, end, }; } editData = args.data; const 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); } }); const layout = new GridLayout({ grouping: { field: 'start', converter(field) { return field.toDateString(); }, }, rowTemplate: monthEventTemplate, groupStrategy: calendar, }); function createEditEventDialog() { const eventDialog = document.getElementById('editDialogTemplate').innerHTML; let div = document.createElement('div'); div.innerHTML = eventDialog; const dialog = div.children[0]; dialog.id = 'editDialog'; return dialog; } window.saveEvent = function saveEvent() { if (editData) { const oldStart = editData.start; const oldEnd = editData.end; editData.topic = $('#editDialog #eventTitleContent')[0].value; const newStartValue = $('#editDialog #datetimepicker1')[0].value; const newEndValue = $('#editDialog #datetimepicker2')[0].value; if (newStartValue && newEndValue) { const newStart = newStartValue.split(':'); const 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]), parseInt(newStart[1]), parseInt(newStart[2]) ); editData.end = new Date( oldEnd.getFullYear(), oldEnd.getMonth(), oldEnd.getDate(), parseInt(newEnd[0]), parseInt(newEnd[1]), parseInt(newEnd[2]) ); const dataView = getDataView(); dataView.invalidate(); } removeDialog(); } }; window.deleteEvent = function deleteEvent(e) { const dataView = getDataView(); dataView.data.removeDataItems(editData.sourceIndex, 1); removeDialog(); }; window.cancelEditEvent = function cancelEditEvent() { removeDialog(); }; window.removeDialog = function removeDialog() { const dialog = document.getElementById('editDialog'); if (dialog) { dialog.parentNode.removeChild(dialog); } }; function formatDate(format, date) { const formatter = new GeneralFormatter(format); return formatter.format(date); } function getMonday(date) { date = new Date(date); date.setDate(date.getDate() - date.getDay()); return date; } function formatTitle(options) { const date = options.startDate; if (options.viewMode === 'Month') { return formatDate('mmmm yyyy', date); } else if (options.viewMode === 'Week') { const d1 = getMonday(date); const 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); } } new Vue({ el: '#root', data: { locale, data, cols, layout, groupingOptions: { viewMode: 'Month', startDate: calendar.options.startDate, }, }, computed: { view() { return this.groupingOptions.viewMode; }, title() { return formatTitle(this.groupingOptions); }, options() { const isMonthView = this.groupingOptions.viewMode === 'Month'; return { rowHeight: isMonthView ? 24 : 50, rowTemplate: isMonthView ? monthEventTemplate : dayEventTemplate, }; }, }, methods: { changeView(view) { this.groupingOptions.viewMode = view; }, }, }); </script>
<template> <div class="btn-group flex0" role="group"> <div class="btn btn-default app-prev" v-on:click="prevMonth"> <i class="demo-icon icon-left-big" /> </div> <div class="btn btn-default app-next" v-on:click="nextMonth"> <i class="demo-icon icon-right-big" /> </div> </div> </template> <script> import Vue from 'vue'; export function getMonth(date, monthCount) { let year = date.getFullYear(); let month = date.getMonth() + monthCount; const day = date.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); } export function getDay(date, daysCount) { const result = new Date(date); const timeSpan = 1000 * 60 * 60 * 24 * (daysCount || 1); result.setTime(result.getTime() + timeSpan); return result; } const Nav = Vue.extend({ props: { options: Object, }, methods: { prevMonth() { let date = this.options.startDate; const view = this.options.viewMode || 'Month'; if (view === 'Month') { date = getMonth(date, -1); } else if (view === 'Week') { date = getDay(date, -7); } else { date = getDay(date, -1); } this.options.startDate = date; }, nextMonth() { let date = this.options.startDate; const view = this.options.viewMode || 'Month'; if (view === 'Month') { date = getMonth(date, 1); } else if (view === 'Week') { date = getDay(date, 7); } else { date = getDay(date, 1); } this.options.startDate = date; }, }, }); Vue.component('calnav', Nav); export default Nav; </script>
import _ from 'lodash'; // timetable export const 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) { const set = new Set(); const result = []; while (result.length < count) { const 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 const now = new Date(Date.now()); const year = now.getFullYear(); const month = now.getMonth(); const wd = now.getDay(); const days = randomSeries(-wd - 2, 9 - wd, data.length); const minutes = [0, 30]; function generateStart(idx) { const day = now.getDate() + days[idx]; const hour = _.random(8, 16); const minute = minutes[_.random(0, 1)]; return new Date(year, month, day, hour, minute, 0); } function overlapFn(events) { return function (startDate) { const start = startDate.getTime(); return ( _.findIndex(events, function (event) { return start >= event.start.getTime() && start <= event.end.getTime(); }) >= 0 ); }; } data.forEach((event, idx) => { const isOverlap = overlapFn(data.slice(0, idx)); let start = generateStart(idx); while (isOverlap(start)) { start = generateStart(idx); } const duration = [60, 90, 120, 150, 180][_.random(0, 1)] * 60 * 1000; event.start = start; event.end = new Date(start.getTime() + duration); });
module.exports = { day: 'Day', week: 'Week', month: 'Month' };
@charset "UTF-8"; @font-face { font-family: "spreadview-demo-icon"; src: url(data:application/font-woff;base64,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) 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/vue/styles.css","DataViews/Calendar/Calendar/vue/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/vue/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"]} */
(function () { const IS_PROD = window.process.env.NODE_ENV === 'production'; const USE_NPM = window.process.env.USE_NPM; const USE_CDN = window.process.env.USE_CDN; const SITE_ROOT = window.process.env.SITE_ROOT; const FRAMEWORK = window.process.env.FRAMEWORK; const ext = IS_PROD ? '.min.js' : '.js'; function js(name) { return name + ext; } function npm(t) { if (!t.file) { t.file = IS_PROD ? t.prod : t.dev; } const version = USE_CDN && t.version ? '@' + t.version : ''; const path = t.pkg + version + '/' + t.file; if (USE_CDN) { return 'https://unpkg.com/' + path; } return 'npm:' + path; } function dv(t) { if (USE_CDN || USE_NPM) { t.file = 'dist/' + t.file + '.min.js'; return npm(t); } return SITE_ROOT + '/static/dataviews/' + js(t.file); } const isTypeScript = FRAMEWORK === 'angular'; const babelConfig = { es2015: true, react: true, }; const meta = { js: { babelOptions: babelConfig, }, ts: { typescriptOptions: { tsconfig: true }, }, }; const map = { // gc.dataviews packages '@grapecity/dataviews.common': dv({pkg:'@grapecity/dataviews.common',file:'gc.dataviews.common',version:'1.8.7'}), '@grapecity/dataviews.core': dv({pkg:'@grapecity/dataviews.core',file:'gc.dataviews.core',version:'1.8.7'}), '@grapecity/dataviews.grid': dv({pkg:'@grapecity/dataviews.grid',file:'gc.dataviews.grid',version:'1.8.7'}), '@grapecity/dataviews.cardlayout': dv({pkg:'@grapecity/dataviews.cardlayout',file:'gc.dataviews.cardlayout',version:'1.8.7'}), '@grapecity/dataviews.masonry': dv({pkg:'@grapecity/dataviews.masonry',file:'gc.dataviews.masonry',version:'1.8.7'}), '@grapecity/dataviews.calendar': dv({pkg:'@grapecity/dataviews.calendar',file:'gc.dataviews.calendar',version:'1.8.7'}), '@grapecity/dataviews.timeline': dv({pkg:'@grapecity/dataviews.timeline',file:'gc.dataviews.timeline',version:'1.8.7'}), '@grapecity/dataviews.trellis': dv({pkg:'@grapecity/dataviews.trellis',file:'gc.dataviews.trellis',version:'1.8.7'}), '@grapecity/dataviews.gantt': dv({pkg:'@grapecity/dataviews.gantt',file:'gc.dataviews.gantt',version:'1.8.7'}), '@grapecity/dataviews.searchbox': dv({pkg:'@grapecity/dataviews.searchbox',file:'gc.dataviews.searchbox',version:'1.8.7'}), '@grapecity/dataviews.react': dv({pkg:'@grapecity/dataviews.react',file:'gc.dataviews.react',version:'1.8.7'}), '@grapecity/dataviews.vue': dv({pkg:'@grapecity/dataviews.vue',file:'gc.dataviews.vue',version:'1.8.7'}), '@grapecity/dataviews.angular': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.angular',version:'1.8.7'}), '@grapecity/dataviews.csvexport': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.csvexport',version:'1.8.7'}), // third-party libs react: npm({pkg:'react',prod:'umd/react.production.min.js',dev:'umd/react.development.js',version:'16.13.1'}), 'react-dom': npm({pkg:'react-dom',prod:'umd/react-dom.production.min.js',dev:'umd/react-dom.development.js',version:'16.13.1'}), 'react-router-dom': npm({pkg:'react-router-dom',prod:'umd/react-router-dom.min.js',dev:'umd/react-router-dom.js',version:'5.2.0'}), 'vue': npm({pkg:'vue',file:'dist/vue.js',version:'2.6.11'}), 'vue-router': npm({pkg:'vue-router',file:'dist/vue-router.js',version:'3.3.4'}), 'lodash': npm({pkg: 'lodash', file: js('lodash')}), 'zone.js': npm({pkg: 'zone.js', file: js('dist/zone')}), 'rxjs': npm({pkg: 'rxjs', file: js('bundles/rxjs.umd')}), 'rxjs/operators': npm({pkg:'rxjs-operators-bundle',prod:'dist/bundle.min.js',dev:'dist/bundle.js',version:'1.0.2'}), '@angular/core': npm({pkg: '@angular/core', file: js('bundles/core.umd')}), '@angular/common': npm({pkg: '@angular/common', file: js('bundles/common.umd')}), '@angular/compiler': npm({pkg: '@angular/compiler', file: js('bundles/compiler.umd')}), '@angular/platform-browser': npm({pkg: '@angular/platform-browser', file: js('bundles/platform-browser.umd')}), '@angular/platform-browser-dynamic': npm({pkg: '@angular/platform-browser-dynamic', file: js('bundles/platform-browser-dynamic.umd')}), '@angular/http': npm({pkg: '@angular/http', file: js('bundles/http.umd')}), '@angular/common/http': npm({pkg: '@angular/common', file: js('bundles/common-http.umd')}), '@angular/router': npm({pkg: '@angular/router', file: js('bundles/router.umd')}), '@angular/forms': npm({pkg: '@angular/forms', file: js('bundles/forms.umd')}), // systemjs plugins 'systemjs-plugin-json': npm({pkg:'systemjs-plugin-json',file:'json.js',version:'0.3.0'}), 'systemjs-plugin-css': npm({pkg:'systemjs-plugin-css',file:'css.js',version:'0.1.37'}), 'systemjs-plugin-babel': npm({pkg:'systemjs-plugin-babel',file:'plugin-babel.js',version:'0.0.25'}), 'systemjs-babel-build': npm({pkg:'systemjs-plugin-babel',file:'systemjs-babel-browser.js',version:'0.0.25'}), 'plugin-typescript': npm({pkg:'plugin-typescript',file:'lib/plugin.js',version:'8.0.0'}), 'typescript': npm({pkg:'typescript',file:'lib/typescript.js',version:'3.9.7'}), 'systemjs-vue-browser': npm({pkg:'systemjs-vue-browser',file:'index.js',version:'1.0.11'}), }; const config = { defaultJSExtensions: true, transpiler: isTypeScript ? 'plugin-typescript' : 'systemjs-plugin-babel', typescriptOptions: { tsconfig: true }, meta: { '*.json': {loader: 'systemjs-plugin-json'}, '*.css': {loader: 'systemjs-plugin-css'}, '*.vue': {loader: 'systemjs-vue-browser'}, '*.js': meta.js, '*.ts': meta.ts, 'app.js': { format: 'esm', babelOptions: babelConfig, }, 'typescript': { exports: 'ts', }, '@grapecity/dataviews.common': { format: 'amd', }, '@grapecity/dataviews.core': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.grid': { format: 'amd', deps: [ '@grapecity/dataviews.common', '@grapecity/dataviews.core', ], }, '@grapecity/dataviews.cardlayout': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.masonry': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.calendar': { format: 'amd', deps: [ '@grapecity/dataviews.common', '@grapecity/dataviews.core', ], }, '@grapecity/dataviews.timeline': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.trellis': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.gantt': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.searchbox': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.react': { format: 'amd', deps: [ 'react', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.vue': { format: 'amd', deps: [ 'vue', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.angular': { format: 'amd', deps: [ '@angular/core', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.csvexport': { format: 'amd', deps: [ '@grapecity/dataviews.common' ], }, }, paths: { // paths serve as alias 'npm:': SITE_ROOT + '/node_modules/', }, // map tells the System loader where to look for things map: map, // packages tells the System loader how to load when no filename and/or no extension packages: { '.': { defaultExtension: isTypeScript ? 'ts' : 'js' }, node_modules: { defaultExtension: 'js' }, } }; // fast format detection to avoid detection by source code using regexp Object.keys(map).filter(function (key) { return !config.meta[key]; }).forEach(function (key) { const path = map[key]; if (path.indexOf('/umd') >= 0 || path.indexOf('.umd') >= 0) { config.meta[key] = { format: 'amd' }; } if (path.indexOf('/cjs') >= 0) { config.meta[key] = { format: 'cjs' }; } }); System.config(config); })(this);