diff --git a/example.html b/example.html index fa82ccb..990ec8d 100644 --- a/example.html +++ b/example.html @@ -1,33 +1,39 @@ - - - - OuiCal Example - - - -
-
+ + + + + OuiCal Example + + + +
+
+ + Google + Outlook + iCal + - - + + + + \ No newline at end of file diff --git a/ouical.js b/ouical.js index 3a13b64..26104b1 100644 --- a/ouical.js +++ b/ouical.js @@ -1,18 +1,18 @@ -;(function(exports) { +; (function (exports) { var MS_IN_MINUTES = 60 * 1000; - var formatTime = function(date) { + var formatTime = function (date) { return date.toISOString().replace(/-|:|\.\d+/g, ''); }; - var calculateEndTime = function(event) { + var calculateEndTime = function (event) { return event.end ? formatTime(event.end) : formatTime(new Date(event.start.getTime() + (event.duration * MS_IN_MINUTES))); }; var calendarGenerators = { - google: function(event) { + google: function (event) { var startTime = formatTime(event.start); var endTime = calculateEndTime(event); @@ -26,13 +26,12 @@ '&location=' + (event.address || ''), '&sprop=&sprop=name:' ].join('')); - return 'Google Calendar'; + return href; }, - yahoo: function(event) { + yahoo: function (event) { var eventDuration = event.end ? - ((event.end.getTime() - event.start.getTime())/ MS_IN_MINUTES) : + ((event.end.getTime() - event.start.getTime()) / MS_IN_MINUTES) : event.duration; // Yahoo dates are crazy, we need to convert the duration from minutes to hh:mm @@ -48,7 +47,7 @@ // Remove timezone from event time var st = formatTime(new Date(event.start - (event.start.getTimezoneOffset() * - MS_IN_MINUTES))) || ''; + MS_IN_MINUTES))) || ''; var href = encodeURI([ 'http://calendar.yahoo.com/?v=60&view=d&type=20', @@ -59,11 +58,10 @@ '&in_loc=' + (event.address || '') ].join('')); - return 'Yahoo! Calendar'; + return href; }, - ics: function(event, eClass, calendarName) { + ics: function (event, eClass, calendarName) { var startTime = formatTime(event.start); var endTime = calculateEndTime(event); @@ -81,20 +79,19 @@ 'END:VEVENT', 'END:VCALENDAR'].join('\n')); - return '' + calendarName + ' Calendar'; + return href; }, - ical: function(event) { + ical: function (event) { return this.ics(event, 'icon-ical', 'iCal'); }, - outlook: function(event) { + outlook: function (event) { return this.ics(event, 'icon-outlook', 'Outlook'); } }; - var generateCalendars = function(event) { + exports.generateCalendars = function (event) { return { google: calendarGenerators.google(event), yahoo: calendarGenerators.yahoo(event), @@ -104,13 +101,13 @@ }; // Create CSS - var addCSS = function() { + var addCSS = function () { if (!document.getElementById('ouical-css')) { document.getElementsByTagName('head')[0].appendChild(generateCSS()); } }; - var generateCSS = function() { + var generateCSS = function () { var styles = document.createElement('style'); styles.id = 'ouical-css'; @@ -120,19 +117,19 @@ }; // Make sure we have the necessary event data, such as start time and event duration - var validParams = function(params) { + var validParams = function (params) { return params.data !== undefined && params.data.start !== undefined && (params.data.end !== undefined || params.data.duration !== undefined); }; - var generateMarkup = function(calendars, clazz, calendarId) { + var generateMarkup = function (calendars, clazz, calendarId) { var result = document.createElement('div'); result.innerHTML = ''; result.innerHTML += ''; - Object.keys(calendars).forEach(function(services) { + Object.keys(calendars).forEach(function (services) { result.innerHTML += calendars[services]; }); @@ -147,26 +144,36 @@ return result; }; - var getClass = function(params) { + var getClass = function (params) { if (params.options && params.options.class) { return params.options.class; } }; - var getOrGenerateCalendarId = function(params) { + var getOrGenerateCalendarId = function (params) { return params.options && params.options.id ? params.options.id : Math.floor(Math.random() * 1000000); // Generate a 6-digit random ID }; - exports.createCalendar = function(params) { + exports.createCalendar = function (params) { if (!validParams(params)) { console.log('Event details missing.'); return; } return generateMarkup(generateCalendars(params.data), - getClass(params), - getOrGenerateCalendarId(params)); + getClass(params), + getOrGenerateCalendarId(params)); }; + + exports.createLinks = function (params) { + if (!validParams(params)) { + console.log('Event details missing.'); + return; + } + return generateCalendars(params.data); + }; + + })(this); diff --git a/ouical.min.js b/ouical.min.js deleted file mode 100644 index 4534373..0000000 --- a/ouical.min.js +++ /dev/null @@ -1 +0,0 @@ -;(function(e){var t=60*1e3;var n=function(e){return e.toISOString().replace(/-|:|\.\d+/g,"")};var r=function(e){return e.end?n(e.end):n(new Date(e.start.getTime()+e.duration*t))};var i={google:function(e){var t=n(e.start);var i=r(e);var s=encodeURI(["https://www.google.com/calendar/render","?action=TEMPLATE","&text="+(e.title||""),"&dates="+(t||""),"/"+(i||""),"&details="+(e.description||""),"&location="+(e.address||""),"&sprop=&sprop=name:"].join(""));return'Google Calendar'},yahoo:function(e){var r=e.end?(e.end.getTime()-e.start.getTime())/t:e.duration;var i=r<600?"0"+Math.floor(r/60):Math.floor(r/60)+"";var s=r%60<10?"0"+r%60:r%60+"";var o=i+s;var u=n(new Date(e.start-e.start.getTimezoneOffset()*t))||"";var a=encodeURI(["http://calendar.yahoo.com/?v=60&view=d&type=20","&title="+(e.title||""),"&st="+u,"&dur="+(o||""),"&desc="+(e.description||""),"&in_loc="+(e.address||"")].join(""));return'Yahoo! Calendar'},ics:function(e,t,i){var s=n(e.start);var o=r(e);var u=encodeURI("data:text/calendar;charset=utf8,"+["BEGIN:VCALENDAR","VERSION:2.0","BEGIN:VEVENT","URL:"+document.URL,"DTSTART:"+(s||""),"DTEND:"+(o||""),"SUMMARY:"+(e.title||""),"DESCRIPTION:"+(e.description||""),"LOCATION:"+(e.address||""),"END:VEVENT","END:VCALENDAR"].join("\n"));return''+i+" Calendar"},ical:function(e){return this.ics(e,"icon-ical","iCal")},outlook:function(e){return this.ics(e,"icon-outlook","Outlook")}};var s=function(e){return{google:i.google(e),yahoo:i.yahoo(e),ical:i.ical(e),outlook:i.outlook(e)}};var o=function(){if(!document.getElementById("ouical-css")){document.getElementsByTagName("head")[0].appendChild(u())}};var u=function(){var e=document.createElement("style");e.id="ouical-css";e.innerHTML="#add-to-calendar-checkbox-label{cursor:pointer}.add-to-calendar-checkbox~a{display:none}.add-to-calendar-checkbox:checked~a{display:block;width:150px;margin-left:20px}input[type=checkbox].add-to-calendar-checkbox{position:absolute;top:-9999px;left:-9999px}.add-to-calendar-checkbox~a:before{width:16px;height:16px;display:inline-block;background-image:url();margin-right:.5em;content:' '}.icon-ical:before{background-position:-68px 0}.icon-outlook:before{}.icon-yahoo:before{background-position:-36px +4px}.icon-google:before{background-position:-52px 0}";return e};var a=function(e){return e.data!==undefined&&e.data.start!==undefined&&(e.data.end!==undefined||e.data.duration!==undefined)};var f=function(e,t,n){var r=document.createElement("div");r.innerHTML='';r.innerHTML+='';Object.keys(e).forEach(function(t){r.innerHTML+=e[t]});r.className="add-to-calendar";if(t!==undefined){r.className+=" "+t}o();r.id=n;return r};var l=function(e){if(e.options&&e.options.class){return e.options.class}};var c=function(e){return e.options&&e.options.id?e.options.id:Math.floor(Math.random()*1e6)};e.createCalendar=function(e){if(!a(e)){console.log("Event details missing.");return}return f(s(e.data),l(e),c(e))}})(this); \ No newline at end of file