mirror of
https://github.com/lukevella/rallly.git
synced 2025-08-03 08:28:35 +02:00
2 lines
No EOL
71 KiB
JavaScript
2 lines
No EOL
71 KiB
JavaScript
angular.module("rallly",["ui.router","ngResource","ngFx","btford.modal"]).config(["$stateProvider","$urlRouterProvider","$locationProvider",function(e,t,n){n.html5Mode(!0),t.otherwise("/notfound"),e.state("index",{url:"/",templateUrl:"templates/home.html",controller:"HomeCtrl"}).state("newevent",{url:"/new",templateUrl:"templates/newevent.html",controller:"NewEventCtrl"}).state("about",{url:"/about",templateUrl:"templates/about.html",controller:"AboutCtrl"}).state("notfound",{url:"/notfound",templateUrl:"templates/notfound.html"}).state("event",{url:"/:id",templateUrl:"templates/event.html",controller:"EventCtrl"}).state("editevent",{url:"/:id/edit",templateUrl:"templates/editevent.html",controller:"EditEventCtrl"})}]).factory("Event",["$resource",function(e){return e("/api/event/:id",{id:"@_id"},{update:{method:"PUT"}})}]).factory("Participant",["$resource",function(e){return e("/api/event/:id/participant/:pid",{id:"@_id",pid:"@pid"},{update:{method:"PUT"}})}]).factory("Title",function(){return{set:function(e){document.title=e}}}),angular.module("rallly").run(["$templateCache",function(e){e.put("templates/about.html",'<div style="max-width:600px">\n <h1>What is Rallly?</h1>\n <div class="rl-page-desc">Rallly is a collaborative scheduling service that makes deciding on a date fast and easy.</div>\n <h2>Hi, I\'m Luke!</h2>\n <p>\n I created Rallly as side project to help me learn some new technologies. I decided to publish it because I thought other people might find it useful. Rallly is a completely free service. In fact it is even open source. You can look at the latest source code on Github.\n </p>\n</div>\n'),e.put("templates/confirmmodal.html",'<div class="rl-modal-overlay" ng-click="modal.cancel()"></div>\n\n<div class="rl-modal">\n <div class="rl-modal-title">{{modal.title}}</div>\n <div class="rl-modal-message">\n {{modal.message}}\n </div>\n <div class="rl-modal-actions">\n <button ng-click="modal.confirm()" ng-show="modal.confirm" class="btn" ng-class="{danger : modal.isDestructive}">{{modal.confirmText}}</button>\n <button ng-click="modal.cancel()" class="btn">{{modal.cancelText}}</button>\n </div>\n</div>\n'),e.put("templates/editevent.html",'<div ng-show="event._id">\n <div class="box">\n\n <div class="box-title">Edit Event</div>\n <div class="box-description">\n You can makes changes to your existing event by changing the fields in the form below.\n </div>\n\n <form novalidate name="form" ng-submit="submit()">\n\n <section class="box-section" user-form form="form" event="event">\n\n </section>\n\n <section class="box-section" event-form form="form" event="event">\n\n </section>\n <section class="box-section" date-form form="form" event="event">\n\n </section>\n <div class="box-controls box-bottom-sticky">\n <button type="submit" ng-show="didChange()" class="btn btn-primary" ng-class="{disabled : !didChange()}">\n Save Changes\n </button>\n <button ng-click="undoChanges()" class="btn" ng-show="didChange()">Undo Changes</button>\n <a href="/{{event._id}}" class="btn" ng-hide="didChange()">Done</a>\n </div>\n\n </form>\n\n </div>\n\n</div>\n'),e.put("templates/event.html",'<div ng-show="event._id">\n <div class="box ">\n <div class="event-header">\n <div class="avatar">\n <img src="/images/eventicon.png" width="32 " />\n </div>\n <div class="details">\n <div class="title">\n {{event.title}}\n </div>\n <div class="subtitle">\n Created by <a href="mailto:{{event.creator.email}}">{{event.creator.name}}</a> • {{event.created | elapsed}}\n </div>\n </div>\n <div class="actions">\n <button class="btn" ng-click="editEvent()">Edit Event</button>\n </div>\n </div>\n <div class="box-side-sticky event-description" ng-show="event.description">{{event.description}}</div>\n <div class="box-bottom-sticky event-location" ng-show="event.location">\n <img src="/images/location.png" width="18" /><a href="http://google.com/maps?q={{event.location}}" target="_blank">{{event.location}}</a>\n </div>\n\n </div>\n <div class="box box-x-scroll">\n <div poll event="event" class="poll" participant="participant">\n </div>\n </div>\n</div>\n'),e.put("templates/home.html",'<div class="page-placeholder">\n <div class="image">\n <img src="/images/mark_large.png" width="67" />\n </div>\n <div class="title">\n Schedule an Event\n </div>\n <div class="content">\n Want to host an event but can’t decide on a date? Click on the button below to start!\n </div>\n <button ng-click="newEvent()" class="btn">Schedule New Event</button>\n</div>\n'),e.put("templates/newevent.html",'<div ng-hide="eventUrl">\n <div class="box" ng-class="{\'animated shake\': form.$submitted && form.$invalid }">\n\n <div class="box-title">Schedule a New Event</div>\n <div class="box-description">\n Fill in the form below to create your event and share it with your friends and colleagues.\n </div>\n\n <form novalidate name="form" ng-submit="submit()">\n <section class="box-section" user-form form="form" event="event">\n\n </section>\n\n <section class="box-section" event-form form="form" event="event">\n\n </section>\n\n <section class="box-section" date-form form="form" event="event">\n\n </section>\n\n <section class="box-section" participants-form form="form" event="event">\n\n </section>\n\n <div class="box-controls box-bottom-sticky">\n <button type="submit" class="btn btn-primary">Create Event</button>\n </div>\n\n </form>\n </div>\n</div>\n<div ng-show="eventUrl" class="box fx-fade-up">\n <div class="box-message">\n <div class="main-image">\n <img src="/images/success_large.png" width="100" />\n </div>\n <div class="title">Event Created</div>\n <div class="content">\n Your event has been created successfully! Make sure you visit the page yourself and fill in the poll.\n </div>\n <div class="mini-divider">\n </div>\n <div class="form-group">\n <input type="text" class="form-control" disabled="true" value="{{eventUrl}}" />\n <a href="{{eventUrl}}" class="btn form-btn">GO</a>\n </div>\n </div>\n</div>\n'),e.put("templates/notfound.html","<h1>Error 404</h1>\n<h2>Not Found</h2>\n"),e.put("templates/directives/poll.html",'<div class="poll-header">\n <div class="header participants-header">\n {{event.participants.length}} participants\n </div>\n <div class="header date-header" ng-repeat="date in event.dates">\n <div class="daticon">\n <div class="dow">\n {{date | date: \'EEE\'}}\n </div>\n <div class="day">\n {{date | date: \'d\'}}\n </div>\n <div class="month">\n {{date | date : \'MMM\'}}\n </div>\n <span class="count" ng-show="selectedDate($index)" ng-class={top:isTopDate($index)}>{{selectedDate($index)}}</span>\n </div>\n </div>\n <div class="header actions-header">\n\n </div>\n</div>\n<div class="poll-body">\n <div class="poll-entry" ng-repeat="participant in event.participants">\n <form novalidate ng-submit="update(participant); editMode = false">\n <div class="cell name-cell">\n <span class="avatar style-{{$index + 1}}">\n <img src="/images/user.png" width="11" />\n </span>\n <input required autocomplete="off" type="text" class="form-control" ng-model="participant.name" ng-show="editMode" value="participant.name"/>\n <span ng-hide="editMode" class="name" ng-click="editMode = true; edit(participant)">{{participant.name}}</span>\n </div>\n <div class="cell vote-cell" ng-repeat="date in event.dates">\n <img src="/images/tick@2x.png" width="16" ng-hide="editMode" ng-if="participant.dates[$index]" />\n <img src="/images/nope@2x.png" width="8" ng-hide="editMode" ng-if="!participant.dates[$index]" />\n <input ng-model="participant.dates[$index]" ng-show="editMode" ng-false-value="false" type="checkbox" />\n <div class="overlay" ng-show="editMode" ng-click="participant.dates[$index] = !participant.dates[$index]"></div>\n </div>\n <div class="cell action-cell">\n <a href="#" ng-hide="editMode" ng-click="editMode = true; edit(participant)" class="btn hover">Edit</a>\n <a href="#" ng-hide="editMode" ng-click="delete(participant)" class="btn danger hover">Delete</a>\n <button ng-show="editMode" type="submit" class="btn">Save</button>\n <a href="#" ng-show="editMode" ng-click="editMode = false; cancel($index)" class="btn">Cancel</a>\n </div>\n </form>\n </div>\n <div class="poll-entry highlight">\n <form novalidate name="formnew" ng-submit="save(participant)">\n <div class="cell name-cell">\n <span class="avatar style-{{participant.style}}">\n <img src="/images/user.png" width="11" />\n </span>\n <input autocomplete="off" name="username" type="text" class="form-control" placeholder="Your name..." ng-model="participant.name" required value="participant.name"/>\n </div>\n <div class="cell vote-cell" ng-repeat="date in event.dates">\n <input ng-model="participant.dates[$index]" ng-false-value="false" type="checkbox" />\n <div class="overlay" ng-click="participant.dates[$index] = !participant.dates[$index]"></div>\n </div>\n <div class="cell action-cell">\n <button type="submit" ng-class="{ \'animated shake\' : formnew.$submitted && formnew.$invalid }" class="btn">Save</button>\n </div>\n </form>\n </div>\n</div>\n'),e.put("templates/directives/eventForm/dateForm.html",'<div class="section-details">\n <div class="section-title">Choose Dates</div>\n <ul class="daticon-list">\n <li ng-repeat="date in event.dates">\n <div class="daticon">\n <div class="dow">\n {{date | date: \'EEE\'}}\n </div>\n <div class="day">\n {{date | date: \'d\'}}\n </div>\n <div class="month">\n {{date | date : \'MMM\'}}\n </div>\n <span class="delete" ng-click="datepicker.unsetDate(date)"></span>\n </div>\n </li>\n </ul>\n</div>\n<div class="section-main">\n <div class="form-row">\n <div class="form-group">\n <label for="email">Calendar</label>\n <span class="form-error" ng-show="(form.datepicker.$dirty || form.$submitted) && form.datepicker.$error.required">\n <img src="/images/error.png" width="14" /> You need to select a few dates\n </span>\n <div datepicker required name="datepicker" control="datepicker" ng-model="event.dates">\n\n </div>\n </div>\n </div>\n</div>\n'),e.put("templates/directives/eventForm/eventForm.html",'<div class="section-details">\n <div class="section-title">Event Details</div>\n</div>\n<div class="section-main">\n <div class="form-row">\n <div class="form-col">\n <div class="form-group">\n <label for="title">Title</label>\n <span class="form-error" ng-show="(form.title.$touched || form.$submitted) && errors.title">\n <img src="/images/error.png" width="14" /> {{errors.title}}\n </span>\n <input id="title" name="title" ng-maxlength="30" required ng-model="event.title" type="text" placeholder="Monthly Meetup..." class="form-control extend"/>\n </div>\n </div>\n <div class="form-col">\n <div class="form-group optional">\n <label for="location">Location</label>\n <span class="form-error" ng-show="(form.location.$touched || form.$submitted) && errors.location">\n <img src="/images/error.png" width="14" /> {{errors.location}}\n </span>\n <input id="location" name="location" ng-model="event.location" ng-maxlength="50" type="text" placeholder="Rick\'s Cafe..." class="form-control extend"/>\n </div>\n </div>\n </div>\n <div class="form-row">\n <div class="form-group optional">\n <label for="description" >Description</label>\n <textarea id="description" name="description" ng-model="event.description" placeholder="Enter Description..." class="form-control extend"></textarea>\n </div>\n </div>\n</div>\n'),e.put("templates/directives/eventForm/participantsForm.html",'<div class="section-details">\n <div class="section-title">Invite Participants</div>\n</div>\n<div class="section-main">\n <div class="form-row">\n <div class="form-group optional">\n <label for="emails">Participant\'s Emails</label>\n <textarea id="emails" ng-list ng-model="event.emails" placeholder="Enter Emails..." class="form-control extend"></textarea>\n </div>\n </div>\n</div>\n</section>\n'),e.put("templates/directives/eventForm/userForm.html",'<div class="section-details">\n <div class="section-title">Your Details</div>\n</div>\n<div class="section-main">\n <div class="form-row">\n <div class="form-col">\n <div class="form-group">\n <label for="name">Name</label>\n <span class="form-error" ng-show="(form.name.$touched || form.$submitted) && errors.name">\n <img src="/images/error.png" width="14" /> {{errors.name}}\n </span>\n <input id="name" name="name" ng-maxlength="30" required ng-model="event.creator.name" type="text" placeholder="John Doe..." class="form-control extend"/>\n </div>\n </div>\n <div class="form-col">\n <div class="form-group">\n <label for="email">Email</label>\n <span class="form-error" ng-show="(form.email.$touched || form.$submitted) && errors.email">\n <img src="/images/error.png" width="14" /> {{errors.email}}\n </span>\n <input type="email" id="email" name="email" ng-pattern="emailRegex" required ng-model="event.creator.email" placeholder="john.doe@email.com..." class="form-control extend"/>\n </div>\n </div>\n </div>\n</div>\n')}]),angular.module("rallly").controller("AboutCtrl",["Title",function(e){e.set("About Rallly")}]),angular.module("rallly").controller("EditEventCtrl",["$scope","$http","$state","$timeout","Event","ConfirmModal","Title",function(e,t,n,i,a,o,l){var r=n.params.id;e.event=a.get({id:r},function(){l.set("Edit: "+e.event.title),e.master=angular.copy(e.event)},function(){n.go("notfound")}),e.undoChanges=function(){e.event=angular.copy(e.master),resetDates()},e.didChange=function(){return JSON.stringify(e.master)!=JSON.stringify(e.event)},e.didChangeDates=function(){return JSON.stringify(e.master.dates)!=JSON.stringify(e.event.dates)},e.submit=function(){if(e.form.$valid)if(e.didChangeDates()){new o({title:"Hold up!",message:"Changing the dates will reset all entries by the participants. Are you sure you want to do that?",confirmText:"Yes, I'm sure",isDestructive:!0,confirm:function(){e.event.participants=[],s()}})}else s();else{new o({title:"Not so fast!",message:"Make sure you fill in all the required fields and try again.",cancelText:"OK"})}};var s=function(){a.update({id:r},e.event,function(){new o({title:"Event Updated",message:"Your changes have been saved successfully!",confirmText:"Back to Event Page",cancelText:"Stay here",confirm:function(){n.go("event",{id:e.event._id})}});e.master=angular.copy(e.event),e.didSave=i(function(){e.didSave=!1},2e3)})}}]),angular.module("rallly").controller("EventCtrl",["$scope","$http","$state","Title","Event",function(e,t,n,i,a){var o=n.params.id;e.participant={},e.event=a.get({id:o},function(){i.set(e.event.title),e.eventUrl=n.href("event",{id:e.event._id},{absolute:!0})},function(){n.go("notfound")}),e.editEvent=function(){n.go("editevent",{id:e.event._id})}}]).directive("poll",["Event","Participant","ConfirmModal",function(e,t,n){return{restrict:"A",templateUrl:"templates/directives/poll.html",scope:{event:"=",participant:"="},link:function(e){e.defaults=[];var i=[];e.delete=function(i){var a=new n({title:"Delete "+i.name+"?",message:"Are you sure you want to remove "+i.name+" from the poll?",confirmText:"Yes - delete",cancelText:"No - nevermind",isDestructive:!0,confirm:function(){t.remove({id:e.event._id,pid:i._id},function(t){e.event=t})}});a.show()},e.isTopDate=function(e){for(var t=i[e],n=0;n<i.length;n++)if(i[n]>t)return!1;return!0},e.selectedDate=function(t){i[t]=0;for(var n=0;n<e.event.participants.length;n++)e.event.participants[n].dates[t]&&i[t]++;return i[t]},e.update=function(n){t.update({id:e.event._id,pid:n._id},n)},e.edit=function(t){e.defaults[e.event.participants.indexOf(t)]=angular.copy(t)},e.cancel=function(t){e.event.participants[t]=e.defaults[t]},e.save=function(n){if(e.formnew.$valid){var n=new t(n);n.$save({id:e.event._id},function(t){e.event=t,e.participant={}}),e.formnew.$setPristine()}}}}}]),angular.module("rallly").controller("HomeCtrl",["$scope","$state","Title",function(e,t,n){n.set("Rallly - Collaborative Scheduling"),e.newEvent=function(){t.go("newevent")}}]),angular.module("rallly").controller("NavigationCtrl",["$scope","$location",function(e,t){e.isActive=function(e){return t.path()==e?!0:!1}}]),angular.module("rallly").controller("NewEventCtrl",["$scope","$http","$state","Event","ConfirmModal",function(e,t,n,i,a){e.title="Schedule a New Event",e.description="Fill in the form below to create your event and share it with your friends and colleagues.";var o=function(e,t){new a({title:e||"Not so fast!",message:t||"Make sure you fill in all the required fields and try again.",cancelText:"OK"})};e.submit=function(){e.form.$valid?t.post("/api/event",e.event).success(function(t){e.event=t,e.eventUrl=n.href("event",{id:e.event._id},{absolute:!0})}).error(function(){o("Uh oh!","There was an error creating your event. Please try again later.")}):o()},e.clearDates=null}]),angular.module("rallly").directive("backImg",function(){return function(e,t,n){var i=n.backImg;t.css({"background-image":"url(/images/"+i+".png)"})}}),angular.module("rallly").directive("datepicker",function(){return{restrict:"A",require:"ngModel",scope:{model:"=ngModel",control:"="},link:function(e,t,n,i){e.model=e.model||[],angular.element(t).datepicker({multidate:!0,todayHighlight:!0}).on("changeDate",function(e){var t=e.dates;t.sort(function(e,t){return e.getTime()>t.getTime()?!0:!1}),i.$setViewValue(t,e)});var a=function(e,n){if(e&&n&&e.length!=n.length){for(var i=[],a=0;a<e.length;a++)i.push(new Date(e[a]));angular.element(t).datepicker("setDates",i)}};e.$watchCollection("model",a),e.control=e.control||{},e.control.unsetDate=function(t){var n=e.model.indexOf(t);e.model.splice(n,1)},i.$validators.required=function(e){return e&&0!=e.length?!0:!1}}}}),angular.module("rallly").service("FormHelper",function(){this.prettyError=function(e,t){return e.required?t+" is required":e.pattern?t+" is invalid":e.maxlength?t+" is too long":!1}}).directive("userForm",["FormHelper",function(e){return{scope:{event:"=",form:"="},templateUrl:"templates/directives/eventForm/userForm.html",link:function(t){t.errors={},t.emailRegex=/^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/,t.$watchCollection("form.name.$error",function(n){t.errors.name=e.prettyError(n,"Name")}),t.$watchCollection("form.email.$error",function(n){t.errors.email=e.prettyError(n,"Email")})}}}]).directive("eventForm",["FormHelper",function(e){return{scope:{event:"=",form:"="},templateUrl:"templates/directives/eventForm/eventForm.html",link:function(t){t.errors={},t.$watchCollection("form.title.$error",function(n){t.errors.title=e.prettyError(n,"Title")}),t.$watchCollection("form.location.$error",function(n){t.errors.location=e.prettyError(n,"Location")})}}}]).directive("dateForm",function(){return{scope:{event:"=",form:"="},templateUrl:"templates/directives/eventForm/dateForm.html"}}).directive("participantsForm",function(){return{scope:{event:"=",form:"="},templateUrl:"templates/directives/eventForm/participantsForm.html"}}),angular.module("rallly").filter("elapsed",["$filter",function(e){return function(t){if(t){var n=Date.parse(t),i=(new Date).getTime(),a=i-n,o=Math.floor(a/1e3),l=Math.floor(o/60),r=Math.floor(l/60),s=Math.floor(r/24);return s>30?"on "+e("date")(t,"MMMM d"):s>1?s+" days ago":1==s?"1 day ago":r>1?r+" hours ago":1==r?"an hour ago":l>1?l+" minutes ago":1==l?"a minute ago":"a few seconds ago"}}}]),angular.module("rallly").factory("ConfirmModal",["btfModal",function(e){return function(t){var n;n=e({templateUrl:"templates/confirmmodal.html",controllerAs:"modal",controller:function(){this.title=t.title,this.message=t.message,this.confirm=t.confirm?function(){t.confirm(),n.deactivate()}:!1,this.cancel=n.deactivate,this.confirmText=t.confirmText||"Confirm",this.cancelText=t.cancelText||"Cancel",this.isDestructive=t.isDestructive}}),n.activate(),this.destroy=function(){n.deactivate()}}}]);
|
||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["main.js","templates.js","controllers/about.controller.js","controllers/editevent.controller.js","controllers/event.controller.js","controllers/home.controller.js","controllers/navigation.controller.js","controllers/newevent.controller.js","directives/backImg.directive.js","directives/datepicker.directive.js","directives/form.directive.js","filters/elapsed.filter.js","services/modal.service.js"],"names":[],"mappings":"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","file":"public/build/app.js","sourcesContent":["angular.module('rallly', ['ui.router','ngResource','ngFx','btford.modal'])\n    .config(function($stateProvider, $urlRouterProvider, $locationProvider){\n        $locationProvider.html5Mode(true);\n        $urlRouterProvider.otherwise(\"/notfound\")\n        $stateProvider\n        .state('index',{\n            url : '/',\n            templateUrl : 'templates/home.html',\n            controller : 'HomeCtrl'\n        })\n        .state('newevent',{\n            url : '/new',\n            templateUrl : 'templates/newevent.html',\n            controller : 'NewEventCtrl'\n        })\n        .state('about', {\n            url : '/about',\n            templateUrl : 'templates/about.html',\n            controller : 'AboutCtrl'\n        })\n        .state('notfound', {\n            url : '/notfound',\n            templateUrl : 'templates/notfound.html'\n        })\n        .state('event',{\n            url : '/:id',\n            templateUrl : 'templates/event.html',\n            controller : 'EventCtrl'\n        })\n        .state('editevent', {\n            url: '/:id/edit',\n            templateUrl : 'templates/editevent.html',\n            controller : 'EditEventCtrl'\n        })\n    })\n    .factory('Event', function($resource){\n        return $resource('/api/event/:id', { id : '@_id' }, {\n            'update' : { method : 'PUT' }\n        });\n    })\n    .factory('Participant', function($resource){\n        return $resource('/api/event/:id/participant/:pid', { id: '@_id', pid : '@pid'}, {\n            'update' : { method : 'PUT' }\n        });\n    })\n    .factory('Title', function(){\n        return {\n            set : function(title){\n                document.title = title;\n            }\n        }\n    });\n","angular.module(\"rallly\").run([\"$templateCache\", function($templateCache) {$templateCache.put(\"templates/about.html\",\"<div style=\\\"max-width:600px\\\">\\n    <h1>What is Rallly?</h1>\\n    <div class=\\\"rl-page-desc\\\">Rallly is a collaborative scheduling service that makes deciding on a date fast and easy.</div>\\n    <h2>Hi, I\\'m Luke!</h2>\\n    <p>\\n        I created Rallly as side project to help me learn some new technologies. I decided to publish it because I thought other people might find it useful. Rallly is a completely free service. In fact it is even open source. You can look at the latest source code on Github.\\n    </p>\\n</div>\\n\");\n$templateCache.put(\"templates/confirmmodal.html\",\"<div class=\\\"rl-modal-overlay\\\" ng-click=\\\"modal.cancel()\\\"></div>\\n\\n<div class=\\\"rl-modal\\\">\\n    <div class=\\\"rl-modal-title\\\">{{modal.title}}</div>\\n    <div class=\\\"rl-modal-message\\\">\\n        {{modal.message}}\\n    </div>\\n    <div class=\\\"rl-modal-actions\\\">\\n        <button ng-click=\\\"modal.confirm()\\\" ng-show=\\\"modal.confirm\\\" class=\\\"btn\\\" ng-class=\\\"{danger : modal.isDestructive}\\\">{{modal.confirmText}}</button>\\n        <button ng-click=\\\"modal.cancel()\\\"  class=\\\"btn\\\">{{modal.cancelText}}</button>\\n    </div>\\n</div>\\n\");\n$templateCache.put(\"templates/editevent.html\",\"<div ng-show=\\\"event._id\\\">\\n    <div class=\\\"box\\\">\\n\\n        <div class=\\\"box-title\\\">Edit Event</div>\\n        <div class=\\\"box-description\\\">\\n            You can makes changes to your existing event by changing the fields in the form below.\\n        </div>\\n\\n        <form novalidate name=\\\"form\\\" ng-submit=\\\"submit()\\\">\\n\\n            <section class=\\\"box-section\\\" user-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n\\n            <section class=\\\"box-section\\\" event-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n            <section class=\\\"box-section\\\" date-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n            <div class=\\\"box-controls box-bottom-sticky\\\">\\n                <button type=\\\"submit\\\" ng-show=\\\"didChange()\\\" class=\\\"btn btn-primary\\\" ng-class=\\\"{disabled : !didChange()}\\\">\\n                    Save Changes\\n                </button>\\n                <button ng-click=\\\"undoChanges()\\\" class=\\\"btn\\\" ng-show=\\\"didChange()\\\">Undo Changes</button>\\n                <a href=\\\"/{{event._id}}\\\" class=\\\"btn\\\" ng-hide=\\\"didChange()\\\">Done</a>\\n            </div>\\n\\n        </form>\\n\\n    </div>\\n\\n</div>\\n\");\n$templateCache.put(\"templates/event.html\",\"<div ng-show=\\\"event._id\\\">\\n    <div class=\\\"box \\\">\\n        <div class=\\\"event-header\\\">\\n            <div class=\\\"avatar\\\">\\n                <img src=\\\"/images/eventicon.png\\\" width=\\\"32  \\\" />\\n            </div>\\n            <div class=\\\"details\\\">\\n                <div class=\\\"title\\\">\\n                    {{event.title}}\\n                </div>\\n                <div class=\\\"subtitle\\\">\\n                    Created by <a href=\\\"mailto:{{event.creator.email}}\\\">{{event.creator.name}}</a> &bull; {{event.created | elapsed}}\\n                </div>\\n            </div>\\n            <div class=\\\"actions\\\">\\n                <button class=\\\"btn\\\" ng-click=\\\"editEvent()\\\">Edit Event</button>\\n            </div>\\n        </div>\\n        <div class=\\\"box-side-sticky event-description\\\" ng-show=\\\"event.description\\\">{{event.description}}</div>\\n        <div class=\\\"box-bottom-sticky event-location\\\" ng-show=\\\"event.location\\\">\\n            <img src=\\\"/images/location.png\\\" width=\\\"18\\\" /><a href=\\\"http://google.com/maps?q={{event.location}}\\\" target=\\\"_blank\\\">{{event.location}}</a>\\n        </div>\\n\\n    </div>\\n    <div class=\\\"box box-x-scroll\\\">\\n        <div poll event=\\\"event\\\" class=\\\"poll\\\" participant=\\\"participant\\\">\\n        </div>\\n    </div>\\n</div>\\n\");\n$templateCache.put(\"templates/home.html\",\"<div class=\\\"page-placeholder\\\">\\n    <div class=\\\"image\\\">\\n        <img src=\\\"/images/mark_large.png\\\" width=\\\"67\\\" />\\n    </div>\\n    <div class=\\\"title\\\">\\n        Schedule an Event\\n    </div>\\n    <div class=\\\"content\\\">\\n        Want to host an event but can’t decide on a date? Click on the button below to start!\\n    </div>\\n    <button ng-click=\\\"newEvent()\\\" class=\\\"btn\\\">Schedule New Event</button>\\n</div>\\n\");\n$templateCache.put(\"templates/newevent.html\",\"<div ng-hide=\\\"eventUrl\\\">\\n    <div class=\\\"box\\\" ng-class=\\\"{\\'animated shake\\': form.$submitted && form.$invalid }\\\">\\n\\n        <div class=\\\"box-title\\\">Schedule a New Event</div>\\n        <div class=\\\"box-description\\\">\\n            Fill in the form below to create your event and share it with your friends and colleagues.\\n        </div>\\n\\n        <form novalidate name=\\\"form\\\" ng-submit=\\\"submit()\\\">\\n            <section class=\\\"box-section\\\" user-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n\\n            <section class=\\\"box-section\\\" event-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n\\n            <section class=\\\"box-section\\\" date-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n\\n            <section class=\\\"box-section\\\" participants-form form=\\\"form\\\" event=\\\"event\\\">\\n\\n            </section>\\n\\n            <div class=\\\"box-controls box-bottom-sticky\\\">\\n                <button type=\\\"submit\\\" class=\\\"btn btn-primary\\\">Create Event</button>\\n            </div>\\n\\n        </form>\\n    </div>\\n</div>\\n<div ng-show=\\\"eventUrl\\\" class=\\\"box fx-fade-up\\\">\\n    <div class=\\\"box-message\\\">\\n            <div class=\\\"main-image\\\">\\n                <img src=\\\"/images/success_large.png\\\" width=\\\"100\\\" />\\n            </div>\\n    <div class=\\\"title\\\">Event Created</div>\\n    <div class=\\\"content\\\">\\n        Your event has been created successfully! Make sure you visit the page yourself and fill in the poll.\\n    </div>\\n    <div class=\\\"mini-divider\\\">\\n    </div>\\n    <div class=\\\"form-group\\\">\\n        <input type=\\\"text\\\" class=\\\"form-control\\\" disabled=\\\"true\\\" value=\\\"{{eventUrl}}\\\" />\\n        <a href=\\\"{{eventUrl}}\\\" class=\\\"btn form-btn\\\">GO</a>\\n    </div>\\n    </div>\\n</div>\\n\");\n$templateCache.put(\"templates/notfound.html\",\"<h1>Error 404</h1>\\n<h2>Not Found</h2>\\n\");\n$templateCache.put(\"templates/directives/poll.html\",\"<div class=\\\"poll-header\\\">\\n    <div class=\\\"header participants-header\\\">\\n        {{event.participants.length}} participants\\n    </div>\\n    <div class=\\\"header date-header\\\" ng-repeat=\\\"date in event.dates\\\">\\n        <div class=\\\"daticon\\\">\\n            <div class=\\\"dow\\\">\\n                {{date | date: \\'EEE\\'}}\\n            </div>\\n            <div class=\\\"day\\\">\\n                {{date | date: \\'d\\'}}\\n            </div>\\n            <div class=\\\"month\\\">\\n                {{date | date : \\'MMM\\'}}\\n            </div>\\n            <span class=\\\"count\\\" ng-show=\\\"selectedDate($index)\\\" ng-class={top:isTopDate($index)}>{{selectedDate($index)}}</span>\\n        </div>\\n    </div>\\n    <div class=\\\"header actions-header\\\">\\n\\n    </div>\\n</div>\\n<div class=\\\"poll-body\\\">\\n    <div class=\\\"poll-entry\\\" ng-repeat=\\\"participant in event.participants\\\">\\n        <form novalidate ng-submit=\\\"update(participant); editMode = false\\\">\\n            <div class=\\\"cell name-cell\\\">\\n                <span class=\\\"avatar style-{{$index + 1}}\\\">\\n                    <img src=\\\"/images/user.png\\\" width=\\\"11\\\" />\\n                </span>\\n                <input required autocomplete=\\\"off\\\" type=\\\"text\\\" class=\\\"form-control\\\" ng-model=\\\"participant.name\\\" ng-show=\\\"editMode\\\" value=\\\"participant.name\\\"/>\\n                <span ng-hide=\\\"editMode\\\" class=\\\"name\\\" ng-click=\\\"editMode = true; edit(participant)\\\">{{participant.name}}</span>\\n            </div>\\n            <div class=\\\"cell vote-cell\\\" ng-repeat=\\\"date in event.dates\\\">\\n                <img src=\\\"/images/tick@2x.png\\\"  width=\\\"16\\\" ng-hide=\\\"editMode\\\" ng-if=\\\"participant.dates[$index]\\\" />\\n                <img src=\\\"/images/nope@2x.png\\\" width=\\\"8\\\" ng-hide=\\\"editMode\\\" ng-if=\\\"!participant.dates[$index]\\\" />\\n                <input ng-model=\\\"participant.dates[$index]\\\" ng-show=\\\"editMode\\\" ng-false-value=\\\"false\\\" type=\\\"checkbox\\\" />\\n                <div class=\\\"overlay\\\" ng-show=\\\"editMode\\\" ng-click=\\\"participant.dates[$index] = !participant.dates[$index]\\\"></div>\\n            </div>\\n            <div class=\\\"cell action-cell\\\">\\n                <a href=\\\"#\\\" ng-hide=\\\"editMode\\\" ng-click=\\\"editMode = true; edit(participant)\\\" class=\\\"btn hover\\\">Edit</a>\\n                <a href=\\\"#\\\" ng-hide=\\\"editMode\\\" ng-click=\\\"delete(participant)\\\" class=\\\"btn danger hover\\\">Delete</a>\\n                <button ng-show=\\\"editMode\\\" type=\\\"submit\\\" class=\\\"btn\\\">Save</button>\\n                <a href=\\\"#\\\" ng-show=\\\"editMode\\\" ng-click=\\\"editMode = false; cancel($index)\\\"  class=\\\"btn\\\">Cancel</a>\\n            </div>\\n        </form>\\n    </div>\\n    <div class=\\\"poll-entry highlight\\\">\\n        <form novalidate name=\\\"formnew\\\" ng-submit=\\\"save(participant)\\\">\\n            <div class=\\\"cell name-cell\\\">\\n                <span class=\\\"avatar style-{{participant.style}}\\\">\\n                    <img src=\\\"/images/user.png\\\" width=\\\"11\\\" />\\n                </span>\\n                <input autocomplete=\\\"off\\\" name=\\\"username\\\" type=\\\"text\\\" class=\\\"form-control\\\" placeholder=\\\"Your name...\\\" ng-model=\\\"participant.name\\\" required value=\\\"participant.name\\\"/>\\n            </div>\\n            <div class=\\\"cell vote-cell\\\" ng-repeat=\\\"date in event.dates\\\">\\n                <input ng-model=\\\"participant.dates[$index]\\\" ng-false-value=\\\"false\\\" type=\\\"checkbox\\\" />\\n                <div class=\\\"overlay\\\" ng-click=\\\"participant.dates[$index] = !participant.dates[$index]\\\"></div>\\n            </div>\\n            <div class=\\\"cell action-cell\\\">\\n                <button type=\\\"submit\\\" ng-class=\\\"{ \\'animated shake\\' : formnew.$submitted && formnew.$invalid  }\\\" class=\\\"btn\\\">Save</button>\\n            </div>\\n        </form>\\n    </div>\\n</div>\\n\");\n$templateCache.put(\"templates/directives/eventForm/dateForm.html\",\"<div class=\\\"section-details\\\">\\n    <div class=\\\"section-title\\\">Choose Dates</div>\\n    <ul class=\\\"daticon-list\\\">\\n        <li ng-repeat=\\\"date in event.dates\\\">\\n            <div class=\\\"daticon\\\">\\n                <div class=\\\"dow\\\">\\n                    {{date | date: \\'EEE\\'}}\\n                </div>\\n                <div class=\\\"day\\\">\\n                    {{date | date: \\'d\\'}}\\n                </div>\\n                <div class=\\\"month\\\">\\n                    {{date | date : \\'MMM\\'}}\\n                </div>\\n                <span class=\\\"delete\\\" ng-click=\\\"datepicker.unsetDate(date)\\\"></span>\\n            </div>\\n        </li>\\n    </ul>\\n</div>\\n<div class=\\\"section-main\\\">\\n    <div class=\\\"form-row\\\">\\n        <div class=\\\"form-group\\\">\\n            <label for=\\\"email\\\">Calendar</label>\\n            <span class=\\\"form-error\\\" ng-show=\\\"(form.datepicker.$dirty || form.$submitted) && form.datepicker.$error.required\\\">\\n                <img src=\\\"/images/error.png\\\" width=\\\"14\\\" /> You need to select a few dates\\n            </span>\\n            <div datepicker required name=\\\"datepicker\\\" control=\\\"datepicker\\\" ng-model=\\\"event.dates\\\">\\n\\n            </div>\\n        </div>\\n    </div>\\n</div>\\n\");\n$templateCache.put(\"templates/directives/eventForm/eventForm.html\",\"<div class=\\\"section-details\\\">\\n    <div class=\\\"section-title\\\">Event Details</div>\\n</div>\\n<div class=\\\"section-main\\\">\\n    <div class=\\\"form-row\\\">\\n        <div class=\\\"form-col\\\">\\n            <div class=\\\"form-group\\\">\\n                <label for=\\\"title\\\">Title</label>\\n                <span class=\\\"form-error\\\" ng-show=\\\"(form.title.$touched || form.$submitted) && errors.title\\\">\\n                    <img src=\\\"/images/error.png\\\" width=\\\"14\\\" /> {{errors.title}}\\n                </span>\\n                <input id=\\\"title\\\" name=\\\"title\\\" ng-maxlength=\\\"30\\\" required ng-model=\\\"event.title\\\" type=\\\"text\\\" placeholder=\\\"Monthly Meetup...\\\" class=\\\"form-control extend\\\"/>\\n            </div>\\n        </div>\\n        <div class=\\\"form-col\\\">\\n            <div class=\\\"form-group optional\\\">\\n                <label for=\\\"location\\\">Location</label>\\n                <span class=\\\"form-error\\\" ng-show=\\\"(form.location.$touched || form.$submitted) && errors.location\\\">\\n                    <img src=\\\"/images/error.png\\\" width=\\\"14\\\" /> {{errors.location}}\\n                </span>\\n                <input id=\\\"location\\\" name=\\\"location\\\" ng-model=\\\"event.location\\\" ng-maxlength=\\\"50\\\" type=\\\"text\\\" placeholder=\\\"Rick\\'s Cafe...\\\" class=\\\"form-control extend\\\"/>\\n            </div>\\n        </div>\\n    </div>\\n    <div class=\\\"form-row\\\">\\n        <div class=\\\"form-group optional\\\">\\n            <label for=\\\"description\\\" >Description</label>\\n            <textarea id=\\\"description\\\" name=\\\"description\\\" ng-model=\\\"event.description\\\" placeholder=\\\"Enter Description...\\\" class=\\\"form-control extend\\\"></textarea>\\n        </div>\\n    </div>\\n</div>\\n\");\n$templateCache.put(\"templates/directives/eventForm/participantsForm.html\",\"<div class=\\\"section-details\\\">\\n    <div class=\\\"section-title\\\">Invite Participants</div>\\n</div>\\n<div class=\\\"section-main\\\">\\n    <div class=\\\"form-row\\\">\\n        <div class=\\\"form-group optional\\\">\\n            <label for=\\\"emails\\\">Participant\\'s Emails</label>\\n            <textarea id=\\\"emails\\\" ng-list ng-model=\\\"event.emails\\\" placeholder=\\\"Enter Emails...\\\" class=\\\"form-control extend\\\"></textarea>\\n        </div>\\n    </div>\\n</div>\\n</section>\\n\");\n$templateCache.put(\"templates/directives/eventForm/userForm.html\",\"<div class=\\\"section-details\\\">\\n    <div class=\\\"section-title\\\">Your Details</div>\\n</div>\\n<div class=\\\"section-main\\\">\\n    <div class=\\\"form-row\\\">\\n        <div class=\\\"form-col\\\">\\n            <div class=\\\"form-group\\\">\\n                <label for=\\\"name\\\">Name</label>\\n                <span class=\\\"form-error\\\" ng-show=\\\"(form.name.$touched || form.$submitted) && errors.name\\\">\\n                    <img src=\\\"/images/error.png\\\" width=\\\"14\\\" /> {{errors.name}}\\n                </span>\\n                <input id=\\\"name\\\" name=\\\"name\\\" ng-maxlength=\\\"30\\\" required ng-model=\\\"event.creator.name\\\" type=\\\"text\\\" placeholder=\\\"John Doe...\\\" class=\\\"form-control extend\\\"/>\\n            </div>\\n        </div>\\n        <div class=\\\"form-col\\\">\\n            <div class=\\\"form-group\\\">\\n                <label for=\\\"email\\\">Email</label>\\n                <span class=\\\"form-error\\\" ng-show=\\\"(form.email.$touched || form.$submitted) && errors.email\\\">\\n                    <img src=\\\"/images/error.png\\\" width=\\\"14\\\" /> {{errors.email}}\\n                </span>\\n                <input type=\\\"email\\\" id=\\\"email\\\" name=\\\"email\\\" ng-pattern=\\\"emailRegex\\\" required ng-model=\\\"event.creator.email\\\" placeholder=\\\"john.doe@email.com...\\\" class=\\\"form-control extend\\\"/>\\n            </div>\\n        </div>\\n    </div>\\n</div>\\n\");}]);","angular.module('rallly')\n.controller('AboutCtrl', function(Title){\n    Title.set('About Rallly')\n});\n","angular.module('rallly')\n.controller('EditEventCtrl', function($scope, $http, $state, $timeout, Event, ConfirmModal, Title){\n    var id = $state.params.id\n    $scope.event = Event.get({id:id}, function(data){\n        Title.set(\"Edit: \" + $scope.event.title);\n        $scope.master = angular.copy($scope.event);\n    }, function(e){\n        $state.go('notfound');\n    });\n    $scope.undoChanges = function(){\n        $scope.event = angular.copy($scope.master);\n        resetDates();\n    }\n    $scope.didChange = function(){\n        return JSON.stringify($scope.master) != JSON.stringify($scope.event);\n    }\n    $scope.didChangeDates = function(){\n        return JSON.stringify($scope.master.dates) != JSON.stringify($scope.event.dates);\n    }\n    $scope.submit = function(){\n        if ($scope.form.$valid){\n            if ($scope.didChangeDates() ){\n                var modal = new ConfirmModal({\n                    title : 'Hold up!',\n                    message : 'Changing the dates will reset all entries by the participants. Are you sure you want to do that?',\n                    confirmText : 'Yes, I\\'m sure',\n                    isDestructive : true,\n                    confirm : function(){\n                        $scope.event.participants = [];\n                        update();\n                    }\n                });\n\n            } else {\n                update();\n            }\n        } else {\n            var modal = new ConfirmModal({\n                title : 'Not so fast!',\n                message : 'Make sure you fill in all the required fields and try again.',\n                cancelText : 'OK'\n            });\n        }\n    }\n    var update = function(){\n        Event.update({\n            id : id\n        }, $scope.event,\n        function(){\n            var modal = new ConfirmModal({\n                title : 'Event Updated',\n                message : 'Your changes have been saved successfully!',\n                confirmText : 'Back to Event Page',\n                cancelText : 'Stay here',\n                confirm : function(){\n                    $state.go('event',{id : $scope.event._id});\n                }\n            });\n            $scope.master = angular.copy($scope.event);\n            $scope.didSave = $timeout(function(){\n                $scope.didSave = false;\n            }, 2000);\n        });\n    }\n});\n","angular.module('rallly')\n.controller('EventCtrl', function($scope, $http, $state, Title, Event){\n    var id = $state.params.id;\n    $scope.participant = {};\n    $scope.event = Event.get({id:id}, function(data){\n        Title.set($scope.event.title);\n        $scope.eventUrl = $state.href('event', {\n            id: $scope.event._id\n        }, {\n            absolute : true\n        });\n    }, function(e){\n        $state.go('notfound');\n    });\n\n    $scope.editEvent = function(){\n        $state.go('editevent', { id : $scope.event._id });\n    }\n\n})\n.directive('poll', function(Event, Participant, ConfirmModal){\n    return {\n        restrict : 'A',\n        templateUrl : 'templates/directives/poll.html',\n        scope : {\n            'event' : '=',\n            'participant' : '='\n        },\n        link : function(scope, el, attrs){\n            scope.defaults = [];\n            var datesCount = [];\n            scope.delete = function(participant){\n                var modal = new ConfirmModal({\n                    title : 'Delete ' + participant.name + '?',\n                    message : 'Are you sure you want to remove '+participant.name+' from the poll?',\n                    confirmText : 'Yes - delete',\n                    cancelText : 'No - nevermind',\n                    isDestructive : true,\n                    confirm : function(){\n                        Participant.remove({ id : scope.event._id , pid : participant._id }, function(event){\n                            scope.event = event;\n                        });\n                    }\n                });\n                modal.show();\n            }\n            scope.isTopDate = function(index){\n                var count = datesCount[index];\n                for (var i = 0; i < datesCount.length; i++){\n                    if (datesCount[i] > count) return false;\n                }\n                return true;\n            }\n            scope.selectedDate = function(index){\n                datesCount[index] = 0;\n                for (var i = 0; i < scope.event.participants.length; i++){\n                    if (scope.event.participants[i].dates[index]) datesCount[index]++;\n                }\n                return datesCount[index];\n            }\n            scope.update = function(participant){\n                Participant.update({\n                    id : scope.event._id,\n                    pid : participant._id\n                }, participant);\n            }\n            scope.edit = function(participant){\n                scope.defaults[scope.event.participants.indexOf(participant)] = angular.copy(participant);\n            }\n            scope.cancel = function(index){\n                scope.event.participants[index] = scope.defaults[index];\n            }\n            scope.save = function(participant){\n                if (scope.formnew.$valid){\n                    var participant = new Participant(participant);\n                    participant.$save({id:scope.event._id}, function(event){\n                        scope.event = event;\n                        scope.participant = {};\n                    });\n                    scope.formnew.$setPristine();\n                }\n            }\n        }\n    }\n});\n","angular.module('rallly')\n.controller('HomeCtrl', function($scope, $state, Title){\n    Title.set('Rallly - Collaborative Scheduling')\n\n    $scope.newEvent = function(){\n        $state.go('newevent');\n    }\n});\n","angular.module('rallly')\n.controller('NavigationCtrl', function($scope, $location){\n    $scope.isActive = function(path) {\n        if ($location.path() == path) {\n            return true;\n        } else {\n            return false\n        }\n    }\n})\n","angular.module('rallly')\n.controller('NewEventCtrl', function($scope, $http, $state, Event, ConfirmModal){\n\n    $scope.title = \"Schedule a New Event\";\n    $scope.description = \"Fill in the form below to create your event and share it with your friends and colleagues.\";\n\n    var showModal = function(title, message){\n        var modal = new ConfirmModal({\n            title : title || 'Not so fast!',\n            message : message || 'Make sure you fill in all the required fields and try again.',\n            cancelText : 'OK'\n        });\n    }\n\n    $scope.submit = function(){\n        if ($scope.form.$valid){\n            $http.post('/api/event', $scope.event)\n            .success(function(event, status, headers, config){\n                $scope.event = event;\n                $scope.eventUrl = $state.href('event', {\n                    id: $scope.event._id\n                }, {\n                    absolute : true\n                });\n            })\n            .error(function(){\n                showModal('Uh oh!', 'There was an error creating your event. Please try again later.');\n            });\n        } else {\n            showModal();\n        }\n    }\n\n    $scope.clearDates = null\n});\n","angular.module('rallly')\n.directive('backImg', function(){\n    return function(scope, element, attrs){\n        var url = attrs.backImg;\n        element.css({\n            'background-image': 'url(/images/' + url +'.png)'\n        });\n    };\n})\n","angular.module('rallly')\n.directive('datepicker', function(){\n    return {\n        restrict : 'A',\n        require : 'ngModel',\n        scope : {\n            model : '=ngModel',\n            control : '='\n        },\n        link : function(scope, el, attrs, ngModel){\n            scope.model = scope.model || [];\n            angular.element(el).datepicker({\n                multidate : true,\n                todayHighlight: true\n            })\n            .on('changeDate', function(e){\n                var dates = e.dates;\n                dates.sort(function(a, b){\n                    if (a.getTime() > b.getTime()) return true;\n                    return false;\n                });\n                ngModel.$setViewValue(dates, e);\n            });\n\n            var update = function(modelValue, oldValue){\n                if (!modelValue || !oldValue || (modelValue.length == oldValue.length)) return;\n                var dates = [];\n                for (var i = 0; i < modelValue.length; i++){\n                    dates.push(new Date(modelValue[i]));\n                }\n                angular.element(el).datepicker('setDates', dates);\n            }\n            scope.$watchCollection('model', update);\n\n            scope.control = scope.control || {};\n            scope.control.unsetDate = function(date){\n                var index = scope.model.indexOf(date);\n                scope.model.splice(index, 1);\n            }\n\n            ngModel.$validators.required = function(modelValue, viewValue){\n                if (!modelValue || modelValue.length == 0){\n                    return false;\n                }\n                return true;\n            }\n\n        }\n    }\n});\n","angular.module('rallly')\n.service('FormHelper', function(){\n    this.prettyError = function(errors, field){\n        if (errors.required) return field + \" is required\";\n        if (errors.pattern) return field + \" is invalid\" ;\n        if (errors.maxlength) return field + \" is too long\";\n        return false;\n    }\n})\n.directive('userForm', function(FormHelper){\n    return {\n        scope : {\n            event : '=',\n            form : '='\n        },\n        templateUrl : 'templates/directives/eventForm/userForm.html',\n        link : function(scope, el, attrs) {\n            scope.errors = {};\n\n            scope.emailRegex = /^([\\w-\\.]+@([\\w-]+\\.)+[\\w-]{2,4})?$/;\n\n            scope.$watchCollection('form.name.$error',function(errors){\n                scope.errors.name = FormHelper.prettyError(errors, \"Name\");\n            });\n\n            scope.$watchCollection('form.email.$error',function(errors){\n                scope.errors.email = FormHelper.prettyError(errors, \"Email\");\n            });\n        }\n    }\n})\n.directive('eventForm', function(FormHelper){\n    return {\n        scope : {\n            event : '=',\n            form : '='\n        },\n        templateUrl : 'templates/directives/eventForm/eventForm.html',\n        link : function(scope, el, attrs) {\n            scope.errors = {};\n\n            scope.$watchCollection('form.title.$error',function(errors){\n                scope.errors.title = FormHelper.prettyError(errors, \"Title\");\n            });\n\n            scope.$watchCollection('form.location.$error',function(errors){\n                scope.errors.location = FormHelper.prettyError(errors, \"Location\");\n            });\n\n        }\n    }\n})\n.directive('dateForm', function(){\n    return {\n        scope : {\n            event : '=',\n            form : '='\n        },\n        templateUrl : 'templates/directives/eventForm/dateForm.html'\n    }\n})\n.directive('participantsForm', function(){\n    return {\n        scope : {\n            event : '=',\n            form : '='\n        },\n        templateUrl : 'templates/directives/eventForm/participantsForm.html'\n    }\n});\n","angular.module('rallly')\n.filter('elapsed', function($filter){\n    return function(date){\n        if (!date) return;\n        var time = Date.parse(date),\n            timeNow = new Date().getTime(),\n            difference = timeNow - time,\n            seconds = Math.floor(difference / 1000),\n            minutes = Math.floor(seconds / 60),\n            hours = Math.floor(minutes / 60),\n            days = Math.floor(hours / 24);\n        if (days > 30) {\n            return 'on ' + $filter('date')(date, 'MMMM d');\n        } else if (days > 1) {\n            return days + \" days ago\";\n        } else if (days == 1) {\n            return \"1 day ago\"\n        } else if (hours > 1) {\n            return hours + \" hours ago\";\n        } else if (hours == 1) {\n            return \"an hour ago\";\n        } else if (minutes > 1) {\n            return minutes + \" minutes ago\";\n        } else if (minutes == 1){\n            return \"a minute ago\";\n        } else {\n            return \"a few seconds ago\";\n        }\n    }\n})\n","angular.module('rallly')\n.factory('ConfirmModal', function(btfModal){\n\n    return function(config){\n        var modal;\n        modal = btfModal({\n            templateUrl : 'templates/confirmmodal.html',\n            controllerAs : 'modal',\n            controller : function(){\n                this.title = config.title\n                this.message = config.message;\n                this.confirm = (config.confirm) ? function(){config.confirm(); modal.deactivate()} : false;\n                this.cancel = modal.deactivate;\n                this.confirmText = config.confirmText || 'Confirm';\n                this.cancelText = config.cancelText || 'Cancel';\n                this.isDestructive = config.isDestructive;\n            }\n        });\n        modal.activate();\n        \n        this.destroy = function(){\n            modal.deactivate();\n        }\n    }\n});\n"],"sourceRoot":"/source/"}
|