Home Plugins js integration for churchsuite
Javascript Integration for ChurchSuite logo

Javascript Integration for ChurchSuite

by Alwyn Barry on WordPress.org

JS Integration for ChurchSuite is provides ChurchSuite event and smallgroup details for display in a Wordpress website.

(0)
Javascript Integration for ChurchSuite - Screenshot 1

JS Integration for ChurchSuite is a plugin to provide ChurchSuite event and
smallgroup details for display in a WordPress website without using iFrames.
The data is drawn from ChurchSuite JSON feeds using the v3 API and is displayed
natively within your website using Javascript. This plugin uses the ChurchSuite
Javascript v3 public API library to implement much of its functionality, but
needs a lot less technical understanding to use in a WP website than trying
to integrate the libraries and write it all from scratch for yourself.
Nonetheless, it is simple to modify the output of the shortcodes to suit
your own needs.

Current features include:

  • Shortcode to return events as ‘cards’ with the event image and details
  • Shortcode to return events in a ‘list’ grouped by date
  • Shortcode to return a Calendar which can move on to subsequent months where needed
  • Shortcode to return groups as ‘cards’ with the group image and details
  • All API requests are cached locally to speed performance

A little Technical information

For the technical among you: This shortcode works on the ‘client side’,
building the in the user’s browser. This can be faster, in some circumstances,
and more responsive to user input.

Difference between this plugin and cs-integration

We also provide the cs-integration plugin. That plugin uses an older
ChurchSuite API which permits more flexibility because a range of parameters can
be provided at call rather than having to create an ’embed configuration’ on
ChurchSuite to pass in the shortcode call. The other plugin also does all the
work on the ‘server side’ so that the server holds the cached data and the
server creates all the html for output. This plugin use Javascript to create
the response and cache in the client browser. The server-side implementation
can be faster for many repeated requests, and is less speed dependent on the
client provision. However the client-side implementation can be faster for an
individual user and more immediately responsive to interaction. This plugin also
uses Alpine.js to output the HTML, which means an end user could change the
output by changing the HTML files without having to get into the php of the
plugin. However, the Alpine.js code isn’t straightforward and so this is likely
to be of little advantage. Really, it’s simply ‘horses for courses’ – you have
the choice of which to use!

Support

If you have a problem or a feature request, please send a message to the author.

Demo

Currently there is no demo site, but we will create examples shortly

Contributions

  • This plugin relies on the Churchsuite v3 Javascript API library
    • (see https://github.com/ChurchSuite/embed-json-script)
  • This plugin uses Alpine.js to process the ChurchSuite events and smallgroup
    information for display

    • (see https://alpinejs.dev/)
  • This plugin uses dayjs to process dates, because this is what the ChurchSuite
    API uses

    • (see https://dayjs.org/)

Usage

  • For each of the examples below:

    • Replace mychurch with the name of your church which you use to get to
      your ChurchSuite site; e.g. trinity or christchurch … see the first name
      after https:// in your Churchsuite link.
    • Replace 62436903-841e-4239-bc95-e6952e17430e with the unique Id for the
      configuration of event or SmallGroup output you want to use. To easily find this
      Unique ID, go to the Settings for Events or SmallGroups, and use the Embed tab
      in the Calendar or SmalGroup Settings page on ChurchSuite to see the
      Configurations (or create new Configurations), and use ‘Preview’ to show the
      configuration you want to base the output on. The Unique ID is the string of
      dash separated hexadecimal characters you will find in the Link for the preview page.
  • For the Event Cards shortcode, place the shortcode into a page or post or
    into a shortcode block. The shortcode will be:

    [cs-js-event-cards church_name=”mychurch” configuration=”62436903-841e-4239-bc95-e6952e17430e”]

    (replacing the church name and the configuration with your church name and
    the Embed configuration unique ID you want to use)

  • For the Event List shortcode, place the shortcode into a page or post or
    into a shortcode block. The shortcode will be:

    [cs-js-event-list church_name=”mychurch” configuration=”62436903-841e-4239-bc95-e6952e17430e”]

    (replacing the church name and the configuration with your church name and
    the Embed configuration unique ID you want to use)

  • For the Calendar shortcode place the shortcode into a page or post or into a
    shortcode block. The shortcode will look like:

    [cs-calendar church_name="mychurch" configuration="62436903-841e-4239-bc95-e6952e17430e"]
    

    (replacing the church name and the configuration with your church name and
    the Embed configuration unique ID you want to use. The configuration should
    be one which returns events for a number of month – the ‘grid’ option is
    best to enable you to select the right data for this shortcode.)

  • For the Smallgroups shortcode, place the shortcode into a page or post or
    into a shortcode block. The shortcode will be:

    [cs-js-smallgroups church_name=”mychurch” configuration=”62436903-841e-4239-bc95-e6952e17430e”]

    (replacing the church name and the configuration with your church name and
    the Embed configuration unique ID you want to use)

Sadly, ChurchSuite developers won’t allow us to use any parameters inline to
modify what data is received. You must use the (very limited) configuration
available in the Embed Configuration. The ‘look and feel’ of the data as
presented on your website can be altered considerably by adding your own CSS
to your theme file – all items output are within their own css classes and so
everything can be styled to fit with your website.

And, if you want to, you can use an HTML block to do your own output using
Alpine.js. Just follow the examples towards the bottom of
https://kingshope.church/events. The libraries you need have been impported for
you by this plugin, and so, for example, a simple unstyled list of event titles
can be generated by adding an HTML block with:



(replacing demo with your church name, and the hex string with your
configuration unique id).

License

The plugin itself is released under the GNU General Public License. A copy of
this license can be found at the license homepage or in the csjs-integration.php
file in the top comment.

Active installations0+
Weekly downloads
13+0.00%
Version1.0.0
Last updated4/23/2025
WordPress version6.4
Tested up to6.8.1
Tags
ChurchSuiteeventsfeatured