bernskioldmedia / events-calendar-ical-feeds
Extends The Events Calendar with iCal feeds that users can subscribe to in their favorite calendar application.
Fund package maintenance!
bernskioldmedia
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 4
Forks: 1
Type:wordpress-plugin
Requires
- php: ^7.4|^8.0
- composer/installers: ~1.0
- spatie/icalendar-generator: ^2.3
Requires (Dev)
- bernskioldmedia/phpcs-wordpress: dev-master
- bernskioldmedia/wp-plugin-base: ^2.3.0
- humbug/php-scoper: dev-master
- yahnis-elsts/plugin-update-checker: ^4.11
This package is auto-updated.
Last update: 2024-10-29 11:26:26 UTC
README
Extends The Events Calendar with iCal feeds that users can subscribe to in their favorite calendar application. By default, in The Events Calendar, users can export an iCalendar feed, but not subscribe to it.
We believe the use for a calendar export is to subscribe so that updates properly reflect. Therefore, this plugin adds a subscribable, auto-updating feed.
Installation
You can install this package via composer.
composer require bernskioldmedia/events-calendar-ical-feeds
You can also install this package by grabbing the built ZIP file from the releases page and uploading it to your plugins folder.
The plugin will update through the core WordPress plugin updater.
Usage
The feed URL is based on the events slug in the settings of The Event Calendar.
For the default slug events
, the feed URL will be: https://yourdomain.com/events/ical-feed
Please note that the default feed is /ical
while this one is at /ical-feed
.
Query Parameters
You can customize which events show up in a feed through the available query parameters.
Setting a start date.
Set a custom start date from when to start fetching events. By default, this is rolling 30 days before the current day.
from=2021-01-01
Setting an end date.
Set a custom end date until when to fetch events. By default, this is rolling six months after the current day.
to=2021-12-31
Showing events for a specific venue
You can create a venue-specific calendar feed by adding the venue parameter and passing the venue ID.
venue=3
Showing events for a specific organizer
You can create an organizer-specific calendar feed by adding the organizer parameter and passing the organizer ID.
organizer=3
Showing events for one or many event categories
You can create an event category-specific calendar feed by adding the category parameter and passing one or more event category IDs, comma-separated.
categories=28
or categories=25,28,93
Controlling how many events to include
You can customize the number of events to show in the calendar. By default, this is 100.
There is an upper limit for performance reasons and to stop anyone from abusing and sinking your server. By default, this is 500 but can be customized in a filter (see below).
amount=250
Filters & Actions
We make a few filters and actions available for customizing and extending.
Controlling the max amount of events in the feed
Define how many items can be at most be included in the feed. No more items will be allowed, even if set via the filters. Defaults to 500
.
// Allow 1000 events to be loaded into the iCal feed. add_filter( 'events_calendar_ical_feeds_max_amount', function(int $max_events, \BernskioldMedia\WP\EventsCalendarIcalFeeds\Calendar_Feed $feed) { return 1000; } );
Customizing the default start date
Define how long before the current dates we should fetch events for the feeds. By default, this is -30 days
and means that events in the past 30 days will show up in the
calendar.
Be mindful of this, as a larger timespan will mean a bigger feed, which has performance implications.
Return any valuable compatible with DateTime
.
// Including events starting 45 days from any given day. add_filter( 'events_calendar_ical_feeds_default_start_date', function( string $start_date ) { return '-45 days'; });
Customizing the default end date
Define how long after the current dates we should fetch events for the feeds. By default, this is to +6 months
and means that events in the next six months will appear in the
calendar.
Be mindful of this, as a larger timespan will mean a bigger feed, which has performance implications.
Return any valuable compatible with DateTime
.
// Including events rolling one year from today. add_filter( 'events_calendar_ical_feeds_default_end_date', function( string $end_date ) { return '+1 year'; });
Customizing the default feed slug
If you don't like the /ical-feed
suffix of the events slug, you can customize it through this filter. Return any one directory level string.
Please note that returning /ical
here will clash with the built-in feed in The Events Calendar.
After changing, don't forget to refresh your permalinks.
// Making the URL /events/subscribe. add_filter( 'events_calendar_ical_feeds_feed_slug', function() { return 'subscribe'; });
Customizing the calendar feed
You can customize the calendar feed before output if you want to add/change/remove anything that this plugin does by default. Please see spatie/icalendar-generator for how to interact with the calendar object.
// Customize the calendar feed. add_action( 'events_calendar_ical_create_calendar', function( \Spatie\IcalendarGenerator\Components\Calendar $calendar ) { // $calendar->... });
Customizing the event object
You can customize the event object before it is added to the calendar feed if you want to add/change/remove anything that this plugin does by default. Please see spatie/icalendar-generator for how to interact with the event object.
This can be used for example to customize the data or to add additional metadata based on the event ID.
// Customize the calendar feed. add_action( 'events_calendar_ical_event_from_id', function( \Spatie\IcalendarGenerator\Components\Event $event, int $event_id ) { // $event->... });
Preventing asset loading
If you don't want this plugin to load its own assets (see below), you can prevent it by returning false from this filter. It returns true by default.
// Prevent Events Calendar iCal Feeds from loading assets. add_action( 'events_calendar_ical_load_assets', '__return_false' );
Assets
This plugin requires Alpine.js for a few frontend operations. Because Alpine.js is something that you might already be running, or have across many projects, we try to be nice when checking for it.
We load it by checking if the handle alpinejs
is already registered. If it is, we won't touch it. Just enqueue it. If it isn't, we'll register and enqueue.
To completely disable loading of assets, see "Preventing asset loading" above.