Customising the Worksheet

Some brothers have said that they would like to display extra information on the Chairman’s Worksheet.

They cited as an example the Watchtower Online Library where in the Meetings section you can see everything pertaining to each assignment.

It is possible to achieve this with Meeting Schedule Assistant if you are willing to make the needed changes.

Note
The line numbers in the examples below are indicative only.

Step 1

The first thing you need to do is create a new XML data file. This will hold the additional information for each item. Here is an example:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?xml version="1.0" encoding="utf-8"?>
<Meetings xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="https://www.publictalksoftware.co.uk/msa">
  <Meeting Week="W20190325">
    <Treasures1>
      <Note>1Co 5:1, 2​—The congregation in Corinth was tolerating an unrepentant wrongdoer</Note>
      <Note>1Co 5:5-8, 13​—Paul told the congregation to remove the “leaven” from their midst and hand the wrongdoer over to Satan (it-2 230, 869-870)</Note>
      <Note>1Co 5:9-11​—The congregation should not keep company with unrepentant wrongdoers (lvs 241, endnote “Disfellowshipping”)</Note>
    </Treasures1>
    <Treasures2>
      <Note>1Co 4:9​—How are God’s human servants “a theatrical spectacle” to angels? (w09 5/15 24 ¶16)</Note>
      <Note>1Co 6:3​—What was Paul evidently referring to when he wrote: “We will judge angels”? (it-2 211)</Note>
    </Treasures2>
    <Living Item="1">
      <Note>Play and discuss the video that shows a publisher using the video from lesson 4 of the Good News brochure to teach a Bible student.</Note>
    </Living>
  </Meeting>
</Meetings>

I called the file OCLMInfo.XML and I saved it in the user application data folder. You would add new weeks to the file yourself and follow the same template.

Step 2

Now you need to make a copy of the Worksheet-Next Students 2019.XSL template and add a link to the new file:

1
2
3
4
5
6
7
8
9
10
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns="http://www.w3.org/1999/xhtml" xmlns:msa="https://www.publictalksoftware.co.uk/msa">
  <xsl:output method="html" indent="yes" version="4.01"
    doctype-system="http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
    doctype-public="//W3C//DTD XHTML 1.0 Transitional//EN"/>
  <xsl:param name="CSSFile1"></xsl:param>
 
  <xsl:variable name="OCLMInfo" select="document('OCLMInfo.XML')"/>
 
  <xsl:template match="/">

Step 3

Next, add the following new template into the file:

332
333
334
335
336
337
338
<xsl:template match="msa:Note" mode="Info">
  <xsl:if test="position() != 1">
    <br style="line-height:2mm;" />
    <br style="line-height:2mm;" />
  </xsl:if>
  <xsl:value-of select="."/>
</xsl:template>

It is up to you to change how you want to display the new information. The above works for the users who requested this functionality.

Step 4

Now we need to get the script to display the extra Treasures From God’s Word details:

212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
<!--Treasures from God's Word-->
<xsl:template name = "Display_TFGW" >
 <xsl:param name = "Class" />

 <xsl:variable name="Week" select="Date/@ThisWeek"/>
 <xsl:variable name="Info"
                    select="$OCLMInfo/msa:Meetings/msa:Meeting[@Week=$Week]"/>

 <div class="containerTFGW">
   <table cellpadding="2" cellspacing="0"  class="tableOuter">
     <tr>
       <td class="textTFGW" colspan="4">
         <xsl:value-of select="//Labels/TreasuresFromGodsWord"/>
       </td>
     </tr>

     <xsl:if test="$Class='M'">
       <!--Bible discussion-->
       <tr>
         <td class="borderDotTimeDuration">
           [<xsl:value-of select="Treasures1/Time/@EndTime24"/>]
         </td>
         <td class="borderDotTime">
           <xsl:value-of select="Treasures1/Time"/>
         </td>
         <td class="borderDotTheme">
           <xsl:value-of select="Treasures1/Theme" disable-output-escaping="yes"/>&#160;
           <span class="textMethod">
             [<xsl:value-of select="Treasures1/Method" disable-output-escaping="yes"/>]
           </span>
         </td>
         <td class="borderDotName">
           <xsl:value-of select="Treasures1/Name"/>&#160;
         </td>
       </tr>
       <tr>
         <td colspan="4" class="cellComments">
           <xsl:apply-templates select="$Info/msa:Treasures1/msa:Note" mode="Info"/>
         </td>
       </tr>

       <!--Digging for spiritual gems-->
       <tr>
         <td class="borderDotTimeDuration">
           [<xsl:value-of select="Treasures2/Time/@EndTime24"/>]
         </td>
         <td class="borderDotTime">
           <xsl:value-of select="Treasures2/Time"/>
         </td>
         <td class="borderDotTheme">
           <xsl:value-of select="Treasures2/Theme" disable-output-escaping="yes"/>&#160;
           <span class="textMethod">
             [<xsl:value-of select="Treasures2/Method" disable-output-escaping="yes"/>]
           </span>
         </td>
         <td class="borderDotName" valign="top">
           <xsl:value-of select="Treasures2/Name"/>&#160;
         </td>
       </tr>
       <tr>
         <td colspan="4" class="cellComments">
           <xsl:apply-templates select="$Info/msa:Treasures2/msa:Note" mode="Info"/>
         </td>
       </tr>
     </xsl:if>

     <!--Bible reading-->
     <tr>
       <td class="borderDotTimeDuration">
         [<xsl:value-of select="BibleReadingTime/@EndTime24"/>]
       </td>
       <td class="borderDotTime">
         <xsl:value-of select="BibleReadingTime"/>
       </td>
       <td class="borderDotTheme">
         <xsl:value-of select="//Labels/BibleReading"/>&#160;
         <span class="textMaterial">
           <xsl:text>[</xsl:text>
           <xsl:value-of select="StudentSourceMaterial/BibleReadingMaterial"/>
           <xsl:text>]</xsl:text>
         </span>
         <br />
         <xsl:choose>
           <xsl:when test="$Class='M'">
             <xsl:apply-templates select="BibleReadingM"/>
           </xsl:when>
           <xsl:when test="$Class='1'">
             <xsl:apply-templates select="BibleReading1"/>
           </xsl:when>
           <xsl:when test="$Class='2'">
             <xsl:apply-templates select="BibleReading2"/>
           </xsl:when>
         </xsl:choose>
         <br />
       </td>
       <td class="borderDotName" valign="top">
         <xsl:choose>
           <xsl:when test="$Class='M'">
             <xsl:value-of select="BibleReadingM"/>&#160;
           </xsl:when>
           <xsl:when test="$Class='1'">
             <xsl:value-of select="BibleReading1"/>&#160;
           </xsl:when>
           <xsl:when test="$Class='2'">
             <xsl:value-of select="BibleReading2"/>&#160;
           </xsl:when>
         </xsl:choose>
       </td>
     </tr>
     <tr>
       <td class="cellComments" colspan="4">
         <br />
         <br />
         <br />
       </td>
     </tr>
   </table>
 </div>
</xsl:template>

Step 5

Finally, we need to get the script to display the extra Living As Christians details:

811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
<!--Living As Christians-->
<xsl:template name = "Display_LAC" >

  <xsl:variable name="Week" select="Date/@ThisWeek"/>
  <xsl:variable name="Info"
                     select="$OCLMInfo/msa:Meetings/msa:Meeting[@Week=$Week]"/>

  <div class="containerLAC">
    <table cellpadding="2" cellspacing="0"  class="tableOuter">
      <tr>
        <td class="textLAC" colspan="4">
          <xsl:value-of select="//Labels/LivingAsChristians"/>
        </td>
      </tr>
      <tr>
        <td class="borderDotTimeDuration">
          [<xsl:value-of select="SongMiddle/@EndTime24"/>]
        </td>
        <td class="borderDotTime">
          <xsl:value-of select="//Labels/SongDuration"/>
        </td>
        <td class="borderDotTheme" colspan="2">
          <xsl:value-of select="//Labels/Song"/>&#160;
          <xsl:value-of select="SongMiddle"/>&#160;
          <span class="textSongTitle">
            <xsl:value-of select="SongMiddle/@Title"/>
          </span>
        </td>
      </tr>
      <tr>
        <td class="borderDotTimeDuration">
          [<xsl:value-of select="LivingAsChristians/Item1/Time/@EndTime24"/>]
        </td>
        <td class="borderDotTime">
          <xsl:value-of select="LivingAsChristians/Item1/Time"/>
        </td>
        <td class="borderDotTheme">
          <xsl:value-of select="LivingAsChristians/Item1/Theme" disable-output-escaping="yes"/>&#160;
          <span class="textMethod">
            [<xsl:value-of select="LivingAsChristians/Item1/Method" disable-output-escaping="yes"/>]
          </span>
          <xsl:call-template name="Display_DemoInfo">
            <xsl:with-param name="Item" select="LivingAsChristians/Item1"/>
          </xsl:call-template>
        </td>
        <td class="borderDotName">
          <xsl:value-of select="LivingAsChristians/Item1/Name"/>&#160;
        </td>
      </tr>
      <tr>
        <td colspan="4" class="cellComments">
          <xsl:apply-templates select="$Info/msa:Living[@Item=1]/msa:Note" mode="Info"/>
        </td>
      </tr>
      <xsl:if test="LivingAsChristians/@ItemCount=2">
        <tr>
          <td class="borderDotTimeDuration">
            [<xsl:value-of select="LivingAsChristians/Item2/Time/@EndTime24"/>]
          </td>
          <td class="borderDotTime">
            <xsl:value-of select="LivingAsChristians/Item2/Time"/>
          </td>
          <td class="borderDotTheme">
            <xsl:value-of select="LivingAsChristians/Item2/Theme" disable-output-escaping="yes"/>&#160;
            <span class="textMethod">
              [<xsl:value-of select="LivingAsChristians/Item2/Method" disable-output-escaping="yes"/>]
            </span>
            <xsl:call-template name="Display_DemoInfo">
              <xsl:with-param name="Item" select="LivingAsChristians/Item2"/>
            </xsl:call-template>
          </td>
          <td class="borderDotName">
            <xsl:value-of select="LivingAsChristians/Item2/Name"/>&#160;
          </td>
        </tr>
        <tr>
          <td colspan="4" class="cellComments">
            <xsl:apply-templates select="$Info/msa:Living[@Item=2]/msa:Note" mode="Info"/>
          </td>
        </tr>
      </xsl:if>
      <xsl:choose>
        <!--We include the congregation bible study information and the review-->
        <xsl:when test="CircuitVisit=0">
          <tr>
            <td class="borderDotTimeDuration">
              [<xsl:value-of select="LivingAsChristians/CongregationBibleStudy/Time/@EndTime24"/>]
            </td>
            <td class="borderDotTime">
              <xsl:value-of select="LivingAsChristians/CongregationBibleStudy/Time"/>
            </td>
            <td class="borderDotTheme">
              <xsl:value-of select="//Labels/CongregationBibleStudy"/>&#160;
              <span class="textCongregationBibleStudyMaterial">
                [<xsl:value-of select="LivingAsChristians/CongregationBibleStudy/SourceMaterial" disable-output-escaping="yes"/>]
              </span><br />
              <xsl:value-of select="//Labels/CBSReader"/>:&#160;<xsl:value-of select="LivingAsChristians/CongregationBibleStudy/Reader"/>
            </td>
            <td class="borderDotName">
              <xsl:value-of select="LivingAsChristians/CongregationBibleStudy/Conductor"/>&#160;
            </td>
          </tr>
          <tr>
            <td class="borderDotTimeDuration">
              [<xsl:value-of select="ClosingComments/Time/@EndTime24"/>]
            </td>
            <td class="borderDotTime">
              <xsl:value-of select="ClosingComments/Time"/>
            </td>
            <td class="borderDotTheme" colspan="2">
              <xsl:value-of select="ClosingComments/Theme"/>
            </td>
          </tr>
          <tr>
            <td class="cellComments" colspan="4">
              <xsl:variable name="AssignHistory" select="document('AssignHistory.xml')"/>
              <xsl:variable name="week" select="Date/@NextWeek"/>
              <xsl:variable name="NextReviewQuestion" select="$AssignHistory/AssignmentHistory/*[name()=$week]/ReviewQuestion"/>
              <xsl:if test="normalize-space($NextReviewQuestion) != ''">
                <xsl:if test="normalize-space(ReviewQuestion) != ''">
                  <span class="textReviewQuestionLabel">
                    <xsl:value-of select="//Labels/NextReviewQuestion"/>&#160;
                  </span>
                  <span class="textReviewQuestion">
                    <xsl:value-of select="$NextReviewQuestion"/>
                  </span>
                  <br />
                </xsl:if>
              </xsl:if>
              <br />
              <br />
              <br />
              <span style="font-size: 8pt;">
                <xsl:apply-templates select="$AssignHistory/AssignmentHistory/*[name()=$week]/StudentItems">
                  <xsl:with-param name="MainHall" select="//Labels/MainHall"/>
                  <xsl:with-param name="AuxClass1" select="//Labels/AuxClass1"/>
                  <xsl:with-param name="AuxClass2" select="//Labels/AuxClass2"/>
                </xsl:apply-templates>
              </span>
            </td>
          </tr>
        </xsl:when>
        <!--We include the review and the circuit overseer talk-->
        <xsl:otherwise>
          <tr>
            <td class="borderDotTimeDuration">
              [<xsl:value-of select="ClosingComments/Time/@EndTime24"/>]
            </td>
            <td class="borderDotTime">
              <xsl:value-of select="ClosingComments/Time"/>
            </td>
            <td class="borderDotTheme" colspan="2">
              <xsl:value-of select="ClosingComments/Theme"/>
            </td>
          </tr>
          <tr>
            <td class="cellComments" colspan="4">
              <xsl:variable name="AssignHistory" select="document('AssignHistory.xml')"/>
              <xsl:variable name="week" select="Date/@NextWeek"/>
              <xsl:variable name="NextReviewQuestion" select="$AssignHistory/AssignmentHistory/*[name()=$week]/ReviewQuestion"/>
              <xsl:if test="normalize-space($NextReviewQuestion) != ''">
                <span class="textReviewQuestionLabel">
                  <xsl:value-of select="//Labels/NextReviewQuestion"/>&#160;
                </span>
                <span class="textReviewQuestion">
                  <xsl:value-of select="$NextReviewQuestion"/>
                </span>
                <br />
              </xsl:if>
              <br />
              <br />
              <br />
              <span style="font-size: 8pt;">
                <xsl:apply-templates select="$AssignHistory/AssignmentHistory/*[name()=$week]/StudentItems">
                  <xsl:with-param name="MainHall" select="//Labels/MainHall"/>
                  <xsl:with-param name="AuxClass1" select="//Labels/AuxClass1"/>
                  <xsl:with-param name="AuxClass2" select="//Labels/AuxClass2"/>
                </xsl:apply-templates>
              </span>
            </td>
          </tr>
          <tr>
            <td class="borderDotTimeDuration">
              [<xsl:value-of select="LivingAsChristians/ItemCircuitOverseer/Time/@EndTime24"/>]
            </td>
            <td class="borderDotTime">
              <xsl:value-of select="LivingAsChristians/ItemCircuitOverseer/Time"/>
            </td>
            <td class="borderDotTheme">
              <xsl:value-of select="LivingAsChristians/ItemCircuitOverseer/Theme" disable-output-escaping="yes"/>&#160;
              <span class="textMethod">
                [<xsl:value-of select="LivingAsChristians/ItemCircuitOverseer/Method" disable-output-escaping="yes"/>]
              </span>
            </td>
            <td class="borderDotName">
              <xsl:value-of select="LivingAsChristians/ItemCircuitOverseer/Name"/>&#160;
            </td>
          </tr>
        </xsl:otherwise>
      </xsl:choose>
      <tr>
        <td class="borderDotTimeDuration">
          [<xsl:value-of select="SongEnd/@EndTime24"/>]
        </td>
        <td class="borderDotTime">
          <xsl:value-of select="//Labels/SongDuration"/>
        </td>
        <td class="borderDotTheme">
          <span class="floatTextLeft">
            <xsl:value-of select="//Labels/Song"/>&#160;
            <xsl:value-of select="SongEnd"/>&#160;
            <span class="textSongTitle">
              <xsl:value-of select="SongEnd/@Title"/>
            </span>
          </span>
          <span class="floatTextRight">
            <xsl:value-of select="//Labels/Prayer"/>
          </span>
        </td>
        <td class="borderDotName">
          <xsl:value-of select="Prayer2"/>&#160;
        </td>
      </tr>
    </table>
  </div>
</xsl:template>

As you can see, there are not many changes that are required. The result should be something like this:

Sample report with additional OCLM information
Sample Result

How to Include the Scriptures with the Song Titles

The following information is applicable to the Sing Out Joyfully to Jehovah publication.

By following the steps below you will be able to include the scriptures on your Workbook or Worksheet.

Step 1

Create a XML data file that includes all of the scripture citations. The following is correct for English:

<?xml version="1.0" encoding="utf-8"?>
<ScripturesForSongs>
 <Song Number="1">(Revelation 4:11)</Song>
 <Song Number="2">(Psalm 83:18)</Song>
 <Song Number="3">(Proverbs 14:26)</Song>
 <Song Number="4">(Psalm 23)</Song>
 <Song Number="5">(Psalm 139)</Song>
 <Song Number="6">(Psalm 19)</Song>
 <Song Number="7">(Isaiah 12:2)</Song>
 <Song Number="8">(Psalm 91)</Song>
 <Song Number="9">(Psalm 97:1)</Song>
 <Song Number="10">(Psalm 145:12)</Song>
 <Song Number="11">(Psalm 19)</Song>
 <Song Number="12">(Exodus 34:6, 7)</Song>
 <Song Number="13">(1 Peter 2:21)</Song>
 <Song Number="14">(Psalm 2:12)</Song>
 <Song Number="15">(Hebrews 1:6)</Song>
 <Song Number="16">(Revelation 21:2)</Song>
 <Song Number="17">(Luke 5:13)</Song>
 <Song Number="18">(Luke 22:20)</Song>
 <Song Number="19">(Matthew 26:26-30)</Song>
 <Song Number="20">(1 John 4:9)</Song>
 <Song Number="21">(Matthew 6:33)</Song>
 <Song Number="22">(Revelation 11:15; 12:10)</Song>
 <Song Number="23">(Revelation 11:15)</Song>
 <Song Number="24">(Isaiah 2:2-4)</Song>
 <Song Number="25">(1 Peter 2:9)</Song>
 <Song Number="26">(Matthew 25:34-40)</Song>
 <Song Number="27">(Romans 8:19)</Song>
 <Song Number="28">(Psalm 15)</Song>
 <Song Number="29">(Isaiah 43:10-12)</Song>
 <Song Number="30">(Hebrews 6:10)</Song>
 <Song Number="31">(Micah 6:8)</Song>
 <Song Number="32">(Exodus 32:26)</Song>
 <Song Number="33">(Psalm 55)</Song>
 <Song Number="34">(Psalm 26)</Song>
 <Song Number="35">(Philippians 1:10)</Song>
 <Song Number="36">(Proverbs 4:23)</Song>
 <Song Number="37">(Matthew 22:37)</Song>
 <Song Number="38">(1 Peter 5:10)</Song>
 <Song Number="39">(Ecclesiastes 7:1)</Song>
 <Song Number="40">(Romans 14:8)</Song>
 <Song Number="41">(Psalm 54)</Song>
 <Song Number="42">(Ephesians 6:18)</Song>
 <Song Number="43">(Psalm 95:2)</Song>
 <Song Number="44">(Psalm 4:1)</Song>
 <Song Number="45">(Psalm 19:14)</Song>
 <Song Number="46">(1 Thessalonians 5:18)</Song>
 <Song Number="47">(1 Thessalonians 5:17)</Song>
 <Song Number="48">(Micah 6:8)</Song>
 <Song Number="49">(Proverbs 27:11)</Song>
 <Song Number="50">(Matthew 22:37)</Song>
 <Song Number="51">(Matthew 16:24)</Song>
 <Song Number="52">(Hebrews 10:7, 9)</Song>
 <Song Number="53">(Jeremiah 1:17)</Song>
 <Song Number="54">(Isaiah 30:20, 21)</Song>
 <Song Number="55">(Matthew 10:28)</Song>
 <Song Number="56">(Proverbs 3:1, 2)</Song>
 <Song Number="57">(1 Timothy 2:4)</Song>
 <Song Number="58">(Luke 10:6)</Song>
 <Song Number="59">(Psalm 146:2)</Song>
 <Song Number="60">(Ezekiel 3:17-19)</Song>
 <Song Number="61">(Luke 16:16)</Song>
 <Song Number="62">(Psalm 98)</Song>
 <Song Number="63">(Isaiah 43:10-12)</Song>
 <Song Number="64">(Matthew 13:1-23)</Song>
 <Song Number="65">(Hebrews 6:1)</Song>
 <Song Number="66">(Revelation 14:6, 7)</Song>
 <Song Number="67">(2 Timothy 4:2)</Song>
 <Song Number="68">(Matthew 13:4-8)</Song>
 <Song Number="69">(2 Timothy 4:5)</Song>
 <Song Number="70">(Matthew 10:11-15)</Song>
 <Song Number="71">(Joel 2:7)</Song>
 <Song Number="72">(Acts 20:20, 21)</Song>
 <Song Number="73">(Acts 4:29)</Song>
 <Song Number="74">(Psalm 98:1)</Song>
 <Song Number="75">(Isaiah 6:8)</Song>
 <Song Number="76">(Hebrews 13:15)</Song>
 <Song Number="77">(2 Corinthians 4:6)</Song>
 <Song Number="78">(Acts 18:11)</Song>
 <Song Number="79">(Matthew 28:19, 20)</Song>
 <Song Number="80">(Psalm 34:8)</Song>
 <Song Number="81">(Ecclesiastes 11:6)</Song>
 <Song Number="82">(Matthew 5:16)</Song>
 <Song Number="83">(Acts 20:20)</Song>
 <Song Number="84">(Matthew 9:37, 38)</Song>
 <Song Number="85">(Romans 15:7)</Song>
 <Song Number="86">(Isaiah 50:4; 54:13)</Song>
 <Song Number="87">(Hebrews 10:24, 25)</Song>
 <Song Number="88">(Psalm 25:4)</Song>
 <Song Number="89">(Luke 11:28)</Song>
 <Song Number="90">(Hebrews 10:24, 25)</Song>
 <Song Number="91">(Psalm 127:1)</Song>
 <Song Number="92">(1 Chronicles 29:16)</Song>
 <Song Number="93">(Hebrews 10:24, 25)</Song>
 <Song Number="94">(Philippians 2:16)</Song>
 <Song Number="95">(Proverbs 4:18)</Song>
 <Song Number="96">(Proverbs 2:1)</Song>
 <Song Number="97">(Matthew 4:4)</Song>
 <Song Number="98">(2 Timothy 3:16, 17)</Song>
 <Song Number="99">(Revelation 7:9, 10)</Song>
 <Song Number="100">(Acts 17:7)</Song>
 <Song Number="101">(Ephesians 4:3)</Song>
 <Song Number="102">(Acts 20:35)</Song>
 <Song Number="103">(Ephesians 4:8)</Song>
 <Song Number="104">(Luke 11:13)</Song>
 <Song Number="105">(1 John 4:7, 8)</Song>
 <Song Number="106">(1 Corinthians 13:1-8)</Song>
 <Song Number="107">(1 John 4:19)</Song>
 <Song Number="108">(Isaiah 55:1-3)</Song>
 <Song Number="109">(1 Peter 1:22)</Song>
 <Song Number="110">(Nehemiah 8:10)</Song>
 <Song Number="111">(Matthew 5:12)</Song>
 <Song Number="112">(Philippians 4:9)</Song>
 <Song Number="113">(John 14:27)</Song>
 <Song Number="114">(James 5:8)</Song>
 <Song Number="115">(2 Peter 3:15)</Song>
 <Song Number="116">(Ephesians 4:32)</Song>
 <Song Number="117">(2 Chronicles 6:41)</Song>
 <Song Number="118">(Luke 17:5)</Song>
 <Song Number="119">(Hebrews 10:38, 39)</Song>
 <Song Number="120">(Matthew 11:28-30)</Song>
 <Song Number="121">(Romans 7:14-25)</Song>
 <Song Number="122">(1 Corinthians 15:58)</Song>
 <Song Number="123">(1 Corinthians 14:33)</Song>
 <Song Number="124">(Psalm 18:25)</Song>
 <Song Number="125">(Matthew 5:7)</Song>
 <Song Number="126">(1 Corinthians 16:13)</Song>
 <Song Number="127">(2 Peter 3:11)</Song>
 <Song Number="128">(Matthew 24:13)</Song>
 <Song Number="129">(Matthew 24:13)</Song>
 <Song Number="130">(Psalm 86:5)</Song>
 <Song Number="131">(Matthew 19:5, 6)</Song>
 <Song Number="132">(Genesis 2:23, 24)</Song>
 <Song Number="133">(Ecclesiastes 12:1)</Song>
 <Song Number="134">(Psalm 127:3-5)</Song>
 <Song Number="135">(Proverbs 27:11)</Song>
 <Song Number="136">(Ruth 2:12)</Song>
 <Song Number="137">(Romans 16:2)</Song>
 <Song Number="138">(Proverbs 16:31)</Song>
 <Song Number="139">(Revelation 21:1-5)</Song>
 <Song Number="140">(John 3:16)</Song>
 <Song Number="141">(Psalm 36:9)</Song>
 <Song Number="142">(Hebrews 6:18, 19)</Song>
 <Song Number="143">(Romans 8:20-25)</Song>
 <Song Number="144">(2 Corinthians 4:18)</Song>
 <Song Number="145">(Luke 23:43)</Song>
 <Song Number="146">(Revelation 21:1-5)</Song>
 <Song Number="147">(Psalm 37:29)</Song>
 <Song Number="148">(2 Samuel 22:1-8)</Song>
 <Song Number="149">(Exodus 15:1)</Song>
 <Song Number="150">(Zephaniah 2:3)</Song>
 <Song Number="151">(Job 14:13-15)</Song>
</ScripturesForSongs>

This file is also available on PastebinScripturesForSongs.xml

Step 2

Next, you need to modify a copy of the XSL stylesheet you are using. It depends upon how your XSL file is constructed. For example:

<!--Open / Close song-->
<xsl:template match="SongOpen|SongEnd">
<td class="textItemWithPadding">
 <xsl:value-of select="//Labels/Song"/>
 <xsl:text> </xsl:text>
 <xsl:value-of select="."/>
 <xsl:text> - </xsl:text>
 <xsl:value-of select="@Title"/>
 <xsl:variable name="ScripturesForSongs" select="document('ScripturesForSongs.xml')"/>
 <xsl:variable name="SongNumber" select="."/>
 &#160;
 <xsl:value-of select="$ScripturesForSongs/ScripturesForSongs/Song[@Number=$SongNumber]"/>
</td>
</xsl:template>

<!--Middle song-->
<xsl:template match="SongMiddle">
<tr>
 <td class="textItemWithPadding">
 <xsl:value-of select="//Labels/Song"/>
 <xsl:text> </xsl:text>
 <xsl:value-of select="."/>
 <xsl:text> - </xsl:text>
 <xsl:value-of select="@Title"/>
 <xsl:variable name="ScripturesForSongs" select="document('ScripturesForSongs.xml')"/>
 <xsl:variable name="SongNumber" select="."/>
 &#160;
 <xsl:value-of select="$ScripturesForSongs/ScripturesForSongs/Song[@Number=$SongNumber]"/>
 </td>
 <td class="textTime">
 <xsl:value-of select="@EndTime12"/>
 </td>
</tr>
</xsl:template>

The above conveys the principles but you will have to adapt it to match the way your XSL style sheet is working.

Results

Here is an example of how it can look on your schedule. The image shown is from a customized XSL stylesheet used by one of our Twi users:

Songs with Scripture Citations