generateParams.xslt 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. Licensed Materials - Property of IBM
  4. IBM Cognos Products: ps
  5. (C) Copyright IBM Corp. 2005, 2011
  6. US Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
  7. -->
  8. <!--
  9. Copyright (C) 2008 Cognos ULC, an IBM Company. All rights reserved.
  10. Cognos (R) is a trademark of Cognos ULC, (formerly Cognos Incorporated).
  11. -->
  12. <xsl:stylesheet version="1.0"
  13. xmlns:xtsext="xalan://com.cognos.xts.ext.XTSExt"
  14. xmlns:cm="http://developer.cognos.com/schemas/xts-cm/1/"
  15. xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  16. xmlns:xsd="http://www.w3.org/2001/XMLSchema"
  17. xmlns:xts="http://developer.cognos.com/schemas/xts/"
  18. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  19. exclude-result-prefixes="xsd xsi xts">
  20. <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="no"/>
  21. <xsl:template match="schedule" priority="1">
  22. <xsl:call-template name="timeParams"/>
  23. <xsl:apply-templates/>
  24. </xsl:template>
  25. <xsl:template match="timeZone" priority="2"/>
  26. <!--
  27. ===============================================================================================
  28. timeParams - even if no schedule was saved we must create these params
  29. ===============================================================================================
  30. -->
  31. <xsl:template name="timeParams" priority="2">
  32. <!-- Date variables -->
  33. <xsl:variable name="xsl_UTC_timeformat" select="'yyyy-MM-dd HH:mm:00'"/>
  34. <xsl:variable name="timeZone" select="timeZone"/>
  35. <xsl:variable name="contentLocale" select="contentLocale"/>
  36. <xsl:variable name="currentTime"><xsl:value-of select="xtsext:getCurrentDateTime(string($timeZone))"/></xsl:variable>
  37. <xsl:variable name="current_day" select="substring(string($currentTime),9,2)"/>
  38. <xsl:variable name="current_month" select="substring(string($currentTime),6,2)"/>
  39. <xsl:variable name="endDate">
  40. <xsl:choose>
  41. <xsl:when test="cm:schedule/cm:endDate[not(@nil)] and not(cm:schedule/cm:type = 'trigger' and cm:schedule/cm:triggerName[@nil])">
  42. <xsl:value-of select="xtsext:formatDateFromUTC(string(cm:schedule/cm:endDate),string($xsl_UTC_timeformat),string($timeZone),string($contentLocale))"/>
  43. </xsl:when>
  44. <xsl:otherwise><xsl:value-of select="$currentTime"/></xsl:otherwise>
  45. </xsl:choose>
  46. </xsl:variable>
  47. <xsl:variable name="startDate">
  48. <xsl:choose>
  49. <xsl:when test="cm:schedule/cm:startDate[not(@nil)] and not(cm:schedule/cm:type = 'trigger' and cm:schedule/cm:triggerName[@nil])">
  50. <xsl:value-of select="xtsext:formatDateFromUTC(string(cm:schedule/cm:startDate),string($xsl_UTC_timeformat),string($timeZone),string($contentLocale))"/>
  51. </xsl:when>
  52. <xsl:otherwise><xsl:value-of select="$currentTime"/></xsl:otherwise>
  53. </xsl:choose>
  54. </xsl:variable>
  55. <param name="current_day"><xsl:value-of select="$current_day"/></param>
  56. <param name="current_month">
  57. <xsl:choose>
  58. <xsl:when test="$current_month='01'">january</xsl:when>
  59. <xsl:when test="$current_month='02'">february</xsl:when>
  60. <xsl:when test="$current_month='03'">march</xsl:when>
  61. <xsl:when test="$current_month='04'">april</xsl:when>
  62. <xsl:when test="$current_month='05'">may</xsl:when>
  63. <xsl:when test="$current_month='06'">june</xsl:when>
  64. <xsl:when test="$current_month='07'">july</xsl:when>
  65. <xsl:when test="$current_month='08'">august</xsl:when>
  66. <xsl:when test="$current_month='09'">september</xsl:when>
  67. <xsl:when test="$current_month='10'">october</xsl:when>
  68. <xsl:when test="$current_month='11'">november</xsl:when>
  69. <xsl:when test="$current_month='12'">december</xsl:when>
  70. </xsl:choose>
  71. </param>
  72. <param name="timezone"><xsl:value-of select="$timeZone"/></param>
  73. <!-- for prompt control start date-->
  74. <param name="p_sched_date1">
  75. <xsl:value-of select="substring(string($startDate),1,10)"/>
  76. </param>
  77. <!-- for prompt control start time -->
  78. <param name="p_sched_time1">
  79. <xsl:value-of select="concat(substring(string($startDate),12,19), '.000')"/>
  80. </param>
  81. <!-- for prompt control end date-->
  82. <param name="p_sched_date2">
  83. <xsl:value-of select="substring(string($endDate),1,10)"/>
  84. </param>
  85. <!-- for prompt control end time -->
  86. <param name="p_sched_time2">
  87. <xsl:value-of select="concat(substring(string($endDate),12,19), '.000')"/>
  88. </param>
  89. </xsl:template>
  90. <!--
  91. ===============================================================================================
  92. if a schedule was saved in CM then produce the proper params
  93. ===============================================================================================
  94. -->
  95. <xsl:template match="cm:schedule" priority="2">
  96. <xsl:variable name="xsl_UTC_timeformat">
  97. <xsl:text>yy-MM-dd'T'HH:mm:00</xsl:text>
  98. </xsl:variable>
  99. <xsl:if test="cm:active='false'">
  100. <param name="m_sp_active">true</param>
  101. </xsl:if>
  102. <xsl:if test="cm:priority[not(@nil)]">
  103. <param name="m_sp_priority">
  104. <xsl:value-of select="cm:priority"/>
  105. </param>
  106. </xsl:if>
  107. <xsl:if test="cm:endType[not(@nil)]">
  108. <param name="m_sp_endType">
  109. <xsl:value-of select="cm:endType"/>
  110. </param>
  111. </xsl:if>
  112. <xsl:if test="cm:type[not(@nil)]">
  113. <param name="m_sp_type">
  114. <xsl:choose>
  115. <xsl:when test="cm:type='monthlyAbsolute' or cm:type='monthlyRelative'">monthly</xsl:when>
  116. <xsl:when test="cm:type='yearlyAbsolute' or cm:type='yearlyRelative'">yearly</xsl:when>
  117. <xsl:otherwise><xsl:value-of select="cm:type"/></xsl:otherwise>
  118. </xsl:choose>
  119. </param>
  120. </xsl:if>
  121. <xsl:if test="cm:triggerName[not(@nil)]">
  122. <param name="m_sp_triggerName">
  123. <xsl:value-of select="cm:triggerName"/>
  124. </param>
  125. </xsl:if>
  126. <xsl:if test="cm:type != 'trigger'">
  127. <xsl:if test="cm:dailyPeriod[not(@nil)]">
  128. <param name="m_sp_dailyPeriod"><xsl:value-of select="cm:dailyPeriod"/></param>
  129. </xsl:if>
  130. <xsl:if test="cm:everyNPeriods[not(@nil)]">
  131. <param name="m_sp_everyNminutes"><xsl:value-of select="cm:everyNPeriods"/></param>
  132. <param name="m_sp_everyNhours"><xsl:value-of select="cm:everyNPeriods"/></param>
  133. <param name="m_sp_everyNdays"><xsl:value-of select="cm:everyNPeriods"/></param>
  134. <param name="m_sp_everyNweeks"><xsl:value-of select="cm:everyNPeriods"/></param>
  135. <param name="m_sp_everyNmonthsAbs"><xsl:value-of select="cm:everyNPeriods"/></param>
  136. <param name="m_sp_everyNmonthsRel"><xsl:value-of select="cm:everyNPeriods"/></param>
  137. </xsl:if>
  138. <xsl:if test="cm:monthlyAbsoluteDay[not(@nil)]">
  139. <param name="m_sp_monthlyAbsoluteDay"><xsl:value-of select="cm:monthlyAbsoluteDay"/></param>
  140. </xsl:if>
  141. <xsl:if test="cm:monthlyRelativeDay[not(@nil)]">
  142. <param name="m_sp_monthlyRelativeDay"><xsl:value-of select="cm:monthlyRelativeDay"/></param>
  143. </xsl:if>
  144. <xsl:if test="cm:monthlyRelativeWeek[not(@nil)]">
  145. <param name="m_sp_monthlyRelativeWeek"><xsl:value-of select="cm:monthlyRelativeWeek"/></param>
  146. </xsl:if>
  147. <xsl:if test="cm:weeklyFriday[not(@nil)]">
  148. <param name="m_sp_weeklyFriday"><xsl:value-of select="cm:weeklyFriday"/></param>
  149. </xsl:if>
  150. <xsl:if test="cm:weeklyMonday[not(@nil)]">
  151. <param name="m_sp_weeklyMonday"><xsl:value-of select="cm:weeklyMonday"/></param>
  152. </xsl:if>
  153. <xsl:if test="cm:weeklySaturday[not(@nil)]">
  154. <param name="m_sp_weeklySaturday"><xsl:value-of select="cm:weeklySaturday"/></param>
  155. </xsl:if>
  156. <xsl:if test="cm:weeklySunday[not(@nil)]">
  157. <param name="m_sp_weeklySunday"><xsl:value-of select="cm:weeklySunday"/></param>
  158. </xsl:if>
  159. <xsl:if test="cm:weeklyThursday[not(@nil)]">
  160. <param name="m_sp_weeklyThursday"><xsl:value-of select="cm:weeklyThursday"/></param>
  161. </xsl:if>
  162. <xsl:if test="cm:weeklyTuesday[not(@nil)]">
  163. <param name="m_sp_weeklyTuesday"><xsl:value-of select="cm:weeklyTuesday"/></param>
  164. </xsl:if>
  165. <xsl:if test="cm:weeklyWednesday[not(@nil)]">
  166. <param name="m_sp_weeklyWednesday"><xsl:value-of select="cm:weeklyWednesday"/></param>
  167. </xsl:if>
  168. <xsl:if test="cm:yearlyAbsoluteDay[not(@nil)]">
  169. <param name="m_sp_yearlyAbsoluteDay"><xsl:value-of select="cm:yearlyAbsoluteDay"/></param>
  170. </xsl:if>
  171. <xsl:if test="cm:yearlyAbsoluteMonth[not(@nil)]">
  172. <param name="m_sp_yearlyAbsoluteMonth"><xsl:value-of select="cm:yearlyAbsoluteMonth"/></param>
  173. </xsl:if>
  174. <xsl:if test="cm:yearlyRelativeDay[not(@nil)]">
  175. <param name="m_sp_yearlyRelativeDay"><xsl:value-of select="cm:yearlyRelativeDay"/></param>
  176. </xsl:if>
  177. <xsl:if test="cm:yearlyRelativeMonth[not(@nil)]">
  178. <param name="m_sp_yearlyRelativeMonth"><xsl:value-of select="cm:yearlyRelativeMonth"/></param>
  179. </xsl:if>
  180. <xsl:if test="cm:yearlyRelativeWeek[not(@nil)]">
  181. <param name="m_sp_yearlyRelativeWeek"><xsl:value-of select="cm:yearlyRelativeWeek"/></param>
  182. </xsl:if>
  183. <xsl:if test="contains(cm:type,'Absolute')">
  184. <param name="sub_type">absolute</param>
  185. </xsl:if>
  186. <xsl:if test="contains(cm:type,'Relative')">
  187. <param name="sub_type">relative</param>
  188. </xsl:if>
  189. <xsl:variable name="currentTime"><xsl:value-of select="xtsext:getCurrentDateTime(string(../timeZone))"/></xsl:variable>
  190. <xsl:variable name="startDate">
  191. <xsl:choose>
  192. <xsl:when test="cm:startDate[not(@nil)] and not(cm:type = 'trigger' and cm:triggerName[@nil])">
  193. <xsl:value-of select="cm:startDate"/>
  194. </xsl:when>
  195. <xsl:otherwise><xsl:value-of select="$currentTime"/></xsl:otherwise>
  196. </xsl:choose>
  197. </xsl:variable>
  198. <xsl:choose>
  199. <xsl:when test="cm:intradayRecurrenceStart[not(@nil)]">
  200. <xsl:variable name="recurrenceStartDateTimeGMT" select="concat(substring-before($startDate,'T'),'T', cm:intradayRecurrenceStart)"/>
  201. <xsl:variable name="recurrenceStartDateTimeUserTZ" select="xtsext:formatDateFromUTC($recurrenceStartDateTimeGMT,string($xsl_UTC_timeformat),string(../timeZone),string(../contentLocale))"/>
  202. <param name="p_intradayRecurrenceStart">
  203. <xsl:value-of select="substring-after($recurrenceStartDateTimeUserTZ,'T')"/>
  204. </param>
  205. </xsl:when>
  206. </xsl:choose>
  207. <xsl:choose>
  208. <xsl:when test="cm:intradayRecurrenceEnd[not(@nil)]">
  209. <xsl:variable name="recurrenceEndDateTimeGMT" select="concat(substring-before($startDate,'T'),'T', cm:intradayRecurrenceEnd)"/>
  210. <xsl:variable name="recurreneEndDateTimeUserTZ" select="xtsext:formatDateFromUTC($recurrenceEndDateTimeGMT,string($xsl_UTC_timeformat),string(../timeZone),string(../contentLocale))"/>
  211. <param name="p_intradayRecurrenceEnd">
  212. <xsl:value-of select="substring-after($recurreneEndDateTimeUserTZ,'T')"/>
  213. </param>
  214. </xsl:when>
  215. </xsl:choose>
  216. <xsl:if test="contains(cm:type,'WithIntradayRecurrence')">
  217. <param name="df_intra">true</param>
  218. </xsl:if>
  219. <xsl:choose>
  220. <xsl:when test="cm:intradayRecurrenceInterval[not(@nil)]">
  221. <!-- cm:intradayRecurrenceInterval is expected in the format: PT#M or PT#H -->
  222. <param name="m_sp_intradayRecurrenceIntervalNum">
  223. <xsl:value-of select="substring-after(substring(cm:intradayRecurrenceInterval, 1, string-length(cm:intradayRecurrenceInterval)-1), 'PT')"/>
  224. </param>
  225. <xsl:variable name="unit" select="substring(cm:intradayRecurrenceInterval, string-length(cm:intradayRecurrenceInterval))"/>
  226. <param name="m_sp_intradayRecurrenceIntervalUnit">
  227. <xsl:value-of select="$unit"/>
  228. </param>
  229. </xsl:when>
  230. </xsl:choose>
  231. </xsl:if>
  232. </xsl:template>
  233. </xsl:stylesheet>