Skip to content

CascadePublicMedia/calendar_link

Repository files navigation

CONTENTS OF THIS FILE

  • Introduction
  • Requirements
  • Installation
  • Configuration
  • Use
  • Examples
  • Maintainers

INTRODUCTION

Calendar links provides two Twig functions for generating links for various calendaring services.

REQUIREMENTS

This module does not require any additional modules outside of Drupal core.

This module uses the spatie/calendar-links library as its foundation. Use composer to install the module (see INSTALLATION) or run composer require spatie/calendar-links separately.

INSTALLATION

CONFIGURATION

There is no configuration available for this module.

USE

This module provides two new Twig functions for generating calendar link URLs:

  1. calendar_link

Returns a string link for a specific calendar type. Available types are:

*. Apple iCal/Microsoft Outlook (ics) *. Google calendar (google) *. Outlook.com (webOutlook) *. Yahoo! calendar (yahoo)

  1. calendar_links

Returns an array of links for all available calendar types. Each array element has the following keys/data:

*. type_key: The calendar type key (ics, google, etc.) *. type_name: The calendar type name ("iCal", "Google", etc.) *. url: The URL for the calendar item.

EXAMPLES

Assume an example "Event" node with the extras fields:

*. Title (string title) *. Start date/time (datetime field_start) *. End date/time (datetime field_end) *. All day event (boolean field_all_day) *. Description (text_format body) *. Location (string field_location)

In a twig template, the following code with generate a link to the event to a Google calendar:

{% set link = calendar_link('google', 
  node.title.value,
  node.field_start.date,
  node.field_end.date,
  node.field_all_day.value,
  node.body.value,
  node.field_location.value
)
%}
<a href="{{ link }}">Add to Google</a>

Or, to create a list of links for each service:

{% set links = calendar_links(
  node.title.value,
  node.field_start.date,
  node.field_end.date,
  node.field_all_day.value,
  node.body.value,
  node.field_location.value
)
%}
<ul>
{% for link in links %}
  <li>
    <a href="{{ link.url }}" 
       class="calendar-link-{{ link.type_key }}">{{ link.type_name }}</a>
  </li>
{% endfor %}

MAINTAINERS

Current maintainers:

Development is sponsored by:

Packages

No packages published

Languages