Skip to content

zionsg/songbooks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Song Books

Transcription of song books in JSON.

The purpose of this project is to store a digital copy of the songbooks, separate data from presentation and facilitate generation of webpages/slides.

Think of it as Mail Merge in Microsoft Word using a Word template with recipients from an Excel spreadsheet - if there are any changes, just change these 2 files and run Mail Merge again, instead of changing 1000 manually typed out Word documents.

Paths in all documentation, even those in subfolders, are relative to the root of the repository. Shell commands are all run from the root of the repository.

Schema

Usage

  • Clone this repository or download the zip file.
  • For convenience, open html/index.html in the browser, which lists all the songbooks in this project.
  • To open a specific songbook manually:
    • Open html/songbook.webpage.html in the browser. This can be run offline without Internet connection except that the links to play/stop the MIDI files will not work.
    • Pass the name of the songbook via the book query param to load the songbook, e.g. file:///C:/Users/Me/Downloads/songbooks/html/songbook.webpage.html?book=songbook-example. This loads the JavaScript file dist/songbook-example.js converted from data/songbook-example.json to allow easier embedding in webpages without worrying about CORS issues, else the webpages must be hosted on a localhost/remote server and cannot be run offline.
    • The webpage also takes in query params css and js for loading of an additional stylesheet and script respectively. See the top docblock in html/songbook.webpage.html for more details.

    • To check which songs do not have titles/lyrics in both languages, open the DevTools console in the browser after the html/songbook.webpage.html is loaded and run the following code:

      let data = utils.getSongbookData();
      
      let missingTitles = [];
      let missingLyrics = [];
      for (const key of Object.keys(data.songs)) {
          let song = data.songs[key];
          let title = song.title;
          let lyrics = song.lyrics;
      
          if (!title.en || !title.cn) {
              missingTitles.push(key);
          }
      
          if (!lyrics.en || !lyrics.cn) {
              missingLyrics.push(key);
          }
      }
      
      console.log('Songs without titles in both languages: ', missingTitles);
      console.log('Songs without lyrics in both languages: ', missingLyrics);
      

Additional assets

  • The files in the assets folder, especially hymns.css and hymns.js, are site-specific (not generic) and hence not put in the html folder. The MIDI files referenced in hymns.js are not stored in this repository.
  • The .js files in the dist folder are generated from the .json files in the data folder, using scripts/data2dist.sh, for easier embedding in webpages without worrying about CORS.

About

Transcription of song books in JSON.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published