The main purpose of this tool is to download the event agenda from ChurchTool as well as the names of the service staff, preparing a PowerPoint slide with the names and portraits to be presented at the beginning of the event.
Additionally, the SongBeamer agenda can be modified by placing slides at the opening or closing, or after specific keywords. Colors of the SongBeamer captions can also be changed.
The ChurchTools song database can also be checked for consistency regarding metadata as well as present .sng files to contain a background image.
A simple installation method (including a generic configuration template that you still
have to configure for your needs) is to execute the following in a cmd.exe
shell:
powershell -ExecutionPolicy ByPass -c "irm https://raw.githubusercontent.com/sbellon/ChurchSong/refs/heads/main/resources/install.ps1 | iex"
A shortcut will be installed on the desktop and command ChurchSong
will be available
from the command line.
If you do not want to use this method, you will have to do a manual install.
The recommendation is to use Python package manager uv which you have to install first and make it accessible via PATH. This can be done by following the steps listed at Standalone Installer.
Afterwards you have to execute uv install ChurchSong
to install ChurchSong itself.
You may put the files ChurchSong.bat
and ChurchSong.ico
from resources
folder
somewhere for convenience as you can just double-click it to load the upcoming agenda
and start SongBeamer.
Command ChurchSong
will be available from the command line afterwards.
Once installed you can update to the latest release version by executing
ChurchSong self update
from the command line.
You can check the location of your configuration files by executing
ChurchSong self info
from the command line. Typically, on Windows, the location of
the configuration file will be %LOCALAPPDATA%\ChurchSong\config.toml
.
You need to adjust the content of %LOCALAPPDATA%\ChurchSong\config.toml
for your
needs (at least base_url
and login_token
).
If you used the simple installation method above, the template was copied there for
you, if you did a manual install you have to copy resources/config.toml.example
there for yourself.
You need to prepare a PowerPoint template with a slide master which contains placeholders for pictures and names for the team members. The ChurchTool's service team name has to be put at the PowerPoint base placeholder via the Select Pane (Alt-F10).
To download the upcoming agenda you can just execute ChurchSong
without any switches
(e.g., double-click it) or use the command agenda
. To specify a starting date to
look for the next event, you can specify additional command line arguments
agenda FROM_DATE
as positional parameter with FROM_DATE
in an ISO date format
(e.g., YYYY-MM-DD
, YYYY-MM-DDT10:00:00
, or YYYY-MM-DDT10:00:00+01:00
).
If everything goes well, the agenda is downloaded into the temp_dir
, the slide is
created from the template, SongBeamer's Schedule.col
is adjusted and finally
SongBeamer itself is launched with the prepared Schedule.col
.
You can keep the temp_dir
as is (it is added to and overwritten in future
invocations), but there is also no harm in deleting the temp_dir
as it is
automatically re-created.
With the additional command family songs verify
you can check the songs for specific
properties like CCLI number, song name, tags, arrangement source, duration and a
SongBeamer .sng
file with the #BackgroundImage
property set.
Without any further argument, songs verify
checks the songs for the next agenda that
would appear when just using agenda
command.
With songs verify FROM_DATE
you can select to only check the songs of the next event
agenda after FROM_DATE
(like agenda FROM_DATE
, FROM_DATE
can be an ISO date
format, e.g., YYYY-MM-DD
, YYYY-MM-DDT10:00:00
, or YYYY-MM-DDT10:00:00+01:00
).
You can check the whole ChurchTools songs database by using songs verify --all
.
By using command options --exclude_tags
and/or --include_tags
you can filter out
songs with specific tags or only include songs with specific tags in the check.