Saturday, 14 September 2013

How to create DashBoard in pentaho Xaction (Action Sequence)

1)Create connection JDBC or JNDI

Example is for MSsql server using JDBC connection.
------------------------------
<actions>      
    <actions>  
      <action-definition>
        <component-name>SQLLookupRule</component-name>
        <action-type>Relational</action-type>
        <action-inputs>
          <SalesID type="string"/>
        </action-inputs>
        <action-outputs>
          <query-result type="result-set" mapping="query_result_policycontact_city"/>
        </action-outputs>
        <component-definition>
<!-- make live FALSE if r getting data from Stored Procedure other wise let it be true -->
          <live><![CDATA[false]]></live> 
          <driver><![CDATA[net.sourceforge.jdts.jdbc.Driver]]></driver> 
          <connection><![CDATA[jdbc:localhost://abhishekConnection:1433/pentaho;instance=policyDB]]></connection> 
          <user-id><![CDATA[abhishekShankar]]></user-id> 
          <password><![CDATA[password@password]]></password> 
<!-- write your query here  -->
          <query><![CDATA[execute dbo.policyforallcity 0;]]></query>
        </component-definition>
      </action-definition>

    </actions>


Now under Action Defination define query result name, to get its value in javascript.

example
------------
 <action-definition>
      <component-name>JavascriptRule</component-name>
      <action-type>JavaScript</action-type>
      <action-inputs>
  <!-- get data from different results set -->
          <query_result_policycontact_city type="result-set"/> 
          <query_result_policycontact_country ="result-set"/> 
          <query_result_policycontact_local ="result-set"/> 
          <query_result_policycontact_employee ="result-set"/> 
        <query_result type="result-set"/>
      </action-inputs>
      <action-outputs>
        <alldata type="string"/> 
        <rowCount type="integer"/>
        <abpolicyCount type="integer"/>
      </action-outputs>
      <component-definition>

3)define a script component defination
under this u can get data from query.
Example
---------
  <component-definition>
<script><![CDATA[alldata ='';
rowCount=query_result.getRowCount();
var abhi=[];

4. Get Values of columns on a variable

<!--
Get Data for cityfrom query_result_policycontact_city query result set .
here city is  on 6th column in query result set so its position is (0,5)
-->
var Current_city= query_result_policycontact_city.getValueAt(0,5);
 <!--
Get Data for country from query_result_policycontact_city query result set .
here country is on 3rd column in query result set so its position is (0,4)
 -->
var previous_country= query_result_policycontact_country.getValueAt(0,4);

Now Create some static Heading for columns under which all data will  shown.

abhi.push("<table id='AbhiTable' border='2' ">");
abhi.push('<tr align="Center"><th>CITY</th>');
abhi.push('<th align="Center" !important;>Country</th>');
abhi.push('<th align="Center" !important;>INR</th> </tr>');


Now Start populating data for each column (i.e city country int....)


now create a for loop


for(row=0;row<rowCount;row++)
{
           var CITY=
query_result_policycontact_city.getValueAt(row,0);
           var Country=
query_result_policycontact_city(row,1);
           var INR=
query_result_policycontact_city(row,2);
       

    <!-- now populate country and city column   -->

       
         {
           abhi.push('<tr><td>'+city_c+'&nbsp;-&nbsp;'+city_c+'</td>');
           abhi.push('<td>'+country_t+'&nbsp;-&nbsp;'+country_t+'</td> ');

<!-- number format or currency format in runtime>
abhi.push('<td>'+city+'&nbsp;-&nbsp;$'+parseFloat(total_INR).toFixed(2).replace(/(\d)(?=(\d\d\d)+(?!\d))/g, "$1,")+'k&nbsp;('+Country+')</td></tr>');

   }
}

 abh.push('</table>');
alldata=tbl.join('');  
]]></script>

   </component-definition>
    </action-definition>
 --------------------------------------------------------------
Kindly post yous comments in case of any issue. Or  contact me spectrumon@gmail.com