Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/brospars/simple-calendar
Simple calendar jquery plugin
https://github.com/brospars/simple-calendar
calendar javascript jquery jquery-plugin
Last synced: 2 months ago
JSON representation
Simple calendar jquery plugin
- Host: GitHub
- URL: https://github.com/brospars/simple-calendar
- Owner: brospars
- License: mit
- Created: 2015-09-15T08:31:39.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-07-25T09:09:57.000Z (over 1 year ago)
- Last Synced: 2024-10-11T21:53:53.649Z (3 months ago)
- Topics: calendar, javascript, jquery, jquery-plugin
- Language: JavaScript
- Homepage: https://brospars.github.io/simple-calendar
- Size: 805 KB
- Stars: 49
- Watchers: 6
- Forks: 38
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# Simple Calendar
![preview](assets/simple-calendar.gif)A simple and easy plugin to create a calendar and add events to it.
## Usage
### Including files
You need to include :
- A recent version of [JQuery](https://jquery.com/)
- The javascript file ``jquery.simple-calendar.js``
- The stylesheet ``simple-calendar.css`````html
```
### Simple usage
Inside a ``$(document).ready();`` function you need to call the plugin on a container jquery element :
```javascript
$(document).ready(function(){
$("#container").simpleCalendar();
});
```This initialize the calendar with its default settings.
### Usage with options
To customize its settings simply overwrite them like below :
```javascript
$(document).ready(function(){
$("#container").simpleCalendar({
//Defaults options below
//string of months starting from january
months: ['january','february','march','april','may','june','july','august','september','october','november','december'],
days: ['sunday','monday','tuesday','wednesday','thursday','friday','saturday'],
displayYear: true, // Display year in header
fixedStartDay: true, // Week begin always by monday or by day set by number 0 = sunday, 7 = saturday, false = month always begin by first day of the month
displayEvent: true, // Display existing event
disableEventDetails: false, // disable showing event details
disableEmptyDetails: false, // disable showing empty date details
events: [], // List of events
onInit: function (calendar) {}, // Callback after first initialization
onMonthChange: function (month, year) {}, // Callback on month change
onDateSelect: function (date, events) {}, // Callback on date selection
onEventSelect: function() {}, // Callback on event selection - use $(this).data('event') to access the event
onEventCreate: function( $el ) {}, // Callback fired when an HTML event is created - see $(this).data('event')
onDayCreate: function( $el, d, m, y ) {} // Callback fired when an HTML day is created - see $(this).data('today'), .data('todayEvents')
});
});
```#### Calendar events
Events are json object that contains `startDate`, `endDate`, and `summary`
```javascript
var events = [{
startDate: Date|timestamp|ISOstring,
endDate: Date|timestamp|ISOstring,
summary: string
}]
```### Methods
To use methods, first get the plugin instance from the data properties and then use the following methods.
```javascript
var container = $("#container").simpleCalendar({ ...code });
let $calendar = container.data('plugin_simpleCalendar')
```#### Add event
```javascript
var newEvent = {
startDate: new Date(new Date().setHours(new Date().getHours() + 48)).toISOString(),
endDate: new Date(new Date().setHours(new Date().getHours() + 49)).getTime(),
summary: 'New event'
}$calendar.addEvent(newEvent)
```#### Set events
```javascript
var events = [{
startDate: new Date(new Date().setHours(new Date().getHours() + 48)).toISOString(),
endDate: new Date(new Date().setHours(new Date().getHours() + 49)).getTime(),
summary: 'New event'
},
{
startDate: new Date(new Date().setHours(new Date().getHours() - 24)).toISOString(),
endDate: new Date(new Date().setHours(new Date().getHours() - 23)).getTime(),
summary: 'New event 2'
}]$calendar.setEvents(events)
```