COGNOiSe.com - The IBM Cognos Community

Legacy Business Intelligence => COGNOS ReportNet => Topic started by: sir_jeroen on 05 Oct 2005 05:06:12 AM

Title: [Script] Some javascripts in actions
Post by: sir_jeroen on 05 Oct 2005 05:06:12 AM
Show your reports!!



I'll start off:

Look in my tutorials section and click on "ReportNet extended"....
http://www.jeroendegraaff.nl/cognoise


Upload your movies/screen dumps etc...

Let me know what you think
Title: Re: Showcase - Show your scripts working
Post by: davidsoc on 06 Oct 2005 05:04:09 AM
 :o OK... tell me how you did that world map!  :o

It's very impressive! All done with sdk or script?
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 06 Oct 2005 05:38:42 AM
No sdk used at all... only javascript... :D
Took some time... but got it finally working....

Tnx for the compliment...
Title: Re: Showcase - Show your scripts working
Post by: CoginAustin on 06 Oct 2005 06:31:44 AM
I actually did the same thing with google maps. Our outside sales reps can pull their address list, click on one and it open google maps in an iframe to show them where it is located :)
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 06 Oct 2005 06:41:49 AM
Yeah right... ;)
Show it :P
Title: Re: Showcase - Show your scripts working
Post by: CoginAustin on 06 Oct 2005 06:54:06 AM
I dont have the ability to record anything but here is the XML , just to prove it..


<report xml:lang="en-us" xmlns="http://developer.cognos.com/schemas/report/1/"><!--RS:1.1-->
<layoutList>
<layout>

<pageSet>

<page name="Page1">
<pageBody><table><tableRow><tableCell><textItem><text>North American Sales Team by City</text><style><stringFormat/><CSS value="font-size:16pt;font-weight:bold;color:navy"/></style></textItem><style><CSS value="padding-bottom:15px"/></style></tableCell><tableCell/></tableRow><tableRow><tableCell>

<selectValue refQuery="Query2" required="false" selectUI="dropdown" parameter="pCity" autoSubmit="true" multiSelect="false"><useItem refItem="City"/><displayItem refItem="City1"/><defaultSelections><defaultSelection>Boston</defaultSelection></defaultSelections></selectValue>
<style><CSS value="text-align:left;vertical-align:top"/></style></tableCell><tableCell/><style><CSS value="text-align:left"/></style></tableRow><tableRow><tableCell>
<style><CSS value="vertical-align:top;text-align:left;padding-bottom:15px"/></style><table><tableRow><tableCell><list refQuery="Query1">
<listColumnTitles><listColumnTitle><textItem><queryItemRef content="label" refItem="Country"/></textItem></listColumnTitle><listColumnTitle><textItem><text>National Flag</text></textItem></listColumnTitle><listColumnTitle><textItem><queryItemRef content="label" refItem="City"/></textItem></listColumnTitle><listColumnTitle><textItem><text>Postal / Zip Code</text></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn refLevel="Country"><textItem><queryItemRef refItem="Country"/></textItem></listColumn><listColumn refLevel="Flag image"><image><queryItemRef refItem="Flag image"/><style><CSS value="width:40px;height:20px"/></style></image></listColumn><listColumn refLevel="City"><textItem><queryItemRef refItem="City"/></textItem></listColumn><listColumn refLevel="Postal zone"><textItem><queryItemRef refItem="Postal zone"/></textItem></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse"/>
</style>
<XMLAttribute name="RS_ListGroupInfo" value="Country|Flag image|City|Postal zone|Address line 1"/></list></tableCell></tableRow><tableRow><tableCell><table><tableRow><tableCell>
<table><tableRow><tableCell><list refQuery="Query1">
<listColumnTitles><listColumnTitle><textItem><text>Office Street Address</text></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn refLevel="Address line 1"><textItem><queryItemRef refItem="Address line 1"/></textItem></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse;margin-top:10px"/>
</style>
<XMLAttribute name="RS_ListGroupInfo" value="Country|Flag image|City|Postal zone|Address line 1"/></list></tableCell><tableCell>
<style><CSS value="vertical-align:top;text-align:left;padding-top:10px"/></style><button>
<textItem>
<text>Office Location</text></textItem>
<expression>[Street Address]</expression></button>
</tableCell></tableRow><style><CSS value="border-collapse:collapse;width:100%"/></style></table></tableCell></tableRow><tableRow><tableCell><list refQuery="Query1">
<listColumnTitles><listColumnTitle><textItem><queryItemRef refItem="City1"/></textItem><textItem><text> Staff Members</text></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn><textItem><queryItemRef refItem="Staff name"/></textItem></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse;vertical-align:text-top;text-align:left;margin-top:10px"/>
</style>
<XMLAttribute name="RS_ListGroupInfo" value="Country|Flag image|City|Postal zone|Address line 1"/></list></tableCell></tableRow><style><CSS value="border-collapse:collapse;width:100%"/></style></table></tableCell></tableRow><style><CSS value="border-collapse:collapse;width:100%"/></style></table></tableCell><tableCell>
<style><CSS value="vertical-align:top;text-align:left"/></style><HTMLItem>
<expression>[Iframe Generator]</expression></HTMLItem>
</tableCell></tableRow><tableRow><tableCell><table><tableRow><tableCell>
<block/>
</tableCell></tableRow><tableRow><tableCell/></tableRow><style><CSS value="border-collapse:collapse;width:100%"/></style></table></tableCell><tableCell/></tableRow><style><CSS value="border-collapse:collapse;width:100%"/></style></table></pageBody>
</page></pageSet></layout>
</layoutList>
<modelConnection name="/content/package[@name='GO Sales and Retailers']/model[@name='model']"/><querySet xml:lang="en-us"><BIQuery name="Query1"><cube><factList><dataItem name="Dynamic URL" aggregate="none"><expression>'http://www.google.com/maps?q='|| Trim([Postal zone])</expression></dataItem><dataItem name="Analyze Hyperlink" aggregate="none"><expression>[Dynamic URL]</expression></dataItem><item refItem="Staff name" aggregate="none"/><dataItem name="Iframe Generator" aggregate="none"><expression>'&lt;iframe src="http://www.google.com/maps?q=' || Replace ([Address line 1], ' ', '+') || '+' || Trim([Postal zone])|| Trim('"')|| ' name="SetIFrame" ' || 'style=" width:610px; height:450px" /&gt;&lt;/iframe&gt;'

</expression></dataItem><item refItem="City1" aggregate="none"/><dataItem name="Street Address" aggregate="none"><expression>'http://www.google.com/maps?q=' || Replace([Address line 1],' ','+') || '+' ||Trim([Postal zone])
</expression></dataItem></factList><dimension name="Country"><level name="Country"><item key="true" refItem="Country" aggregate="none"/></level><level name="Flag image"><item key="true" refItem="Flag image" aggregate="none"/></level><level name="City"><item key="true" refItem="City" aggregate="none"/></level><level name="Postal zone"><item key="true" refItem="Postal zone" aggregate="none"/></level><level name="Address line 1"><item key="true" refItem="Address line 1" aggregate="none"/></level></dimension></cube><tabularModel><dataItem name="Postal zone" aggregate="none"><expression>[gosales_goretailers].[Sales branch address].[Postal zone]</expression></dataItem><dataItem name="Staff name" aggregate="none"><expression>[gosales_goretailers].[Sales reps].[Staff name]</expression></dataItem><dataItem name="Country" aggregate="none"><expression>[gosales_goretailers].[Countries].[Country]</expression></dataItem><dataItem name="Flag image" aggregate="none"><expression>[gosales_goretailers].[Countries].[Flag image]</expression></dataItem><dataItem name="Address line 1" aggregate="none"><expression>[gosales_goretailers].[Sales branch address].[Address line 1]</expression></dataItem><dataItem name="City" aggregate="none"><expression>[gosales_goretailers].[Sales branch address].[City]</expression></dataItem><filter use="optional"><condition>[gosales_goretailers].[Sales branch address].[City] = ?pCity?</condition></filter><filter><condition>[gosales_goretailers].[Sales branch address].[Country] in ('Canada', 'Mexico', 'United States')</condition></filter><dataItem name="City1" aggregate="none"><expression>[gosales_goretailers].[Sales branch address].[City]</expression></dataItem></tabularModel></BIQuery><BIQuery name="Query2"><cube><factList><item refItem="City" aggregate="none" isHeader="true"/><item refItem="City1" aggregate="none" isHeader="true"/></factList></cube><tabularModel><dataItem name="City" aggregate="none"><expression>[gosales_goretailers].[Sales branch address].[City]</expression></dataItem><dataItem name="City1" sort="ascending" aggregate="none"><expression>[gosales_goretailers].[Sales branch address].[City]</expression></dataItem><filter><condition>[gosales_goretailers].[Sales branch address].[Country] in ('Canada', 'Mexico', 'United States')</condition></filter></tabularModel></BIQuery></querySet></report>
Title: Re: Showcase - Show your scripts working
Post by: CoginAustin on 06 Oct 2005 07:01:20 AM
Screenshot attached.. It uses google local because it makes it easier to find things if you can quickly look at whats around it as well :)
This was my inspiration not the final product. You can actually use the above XML and "copy from clipboard" to use it on your Go Sales package. I also must thank Pat Dolinger at Cognos for help with this :)

Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 06 Oct 2005 11:00:43 AM
Looks great!!
But ... you pass the address parameters in the url... am I correct?
In my example I use the Google API in my code (yep... it's googlemaps too :) )
Does your code also work with the API?

Anyway looks great!!
Title: Re: Showcase - Show your scripts working
Post by: CoginAustin on 06 Oct 2005 11:13:12 AM
Yes, it gets passed in the URL. I am not sure the API works with google local? I will have to check it out again..
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 06 Oct 2005 12:30:16 PM
yes it does... that's how it works for me :D
Title: Re: Showcase - Show your scripts working
Post by: JoeBass on 07 Oct 2005 08:58:37 AM
RN A, Your clickable map report looks great.  Can you show the source?  Thanks. 
Title: Re: Showcase - Show your scripts working
Post by: JoeBass on 11 Oct 2005 02:41:59 PM
Hi again,  Hope I'm not breaking one of the board rules by bumping this thread. 

I understand that you don't want to share the code behind your clickable map report.  Can you share with me if it is a data-driven map, or are you hard-coding clickable hot spots? 

I work for an expanding company that could benefit from a map like yours - cool idea.
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 11 Oct 2005 02:59:20 PM
you can contact me using msn chat... See my profile for details...
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 11 Oct 2005 03:50:33 PM
and to make you curious: it's data driven :D
Title: Re: Showcase - Show your scripts working
Post by: JoeBass on 11 Oct 2005 03:51:51 PM
My interest is piqued!  I would like to follow up but, I will be away from the PC for some time.  Thank you.
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 11 Oct 2005 03:58:18 PM
Just as I'd like to have you :P
Title: Re: Showcase - Show your scripts working
Post by: jolly on 12 Oct 2005 06:22:30 AM
Really good. And here is one of my Reports. Small but helpfull for the Users.(//). The Event onMouseOver highlited the complete row.

Cu Jolly
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 12 Oct 2005 06:52:30 AM
Wow... that looks great!!

All javascript I suppose?  Btw I'm curious.. How did you do that top bar (that one with Administrator and Report viewer text).... And this is CRN 1.1 MR2 or CRN 8??
Title: Re: Showcase - Show your scripts working
Post by: jolly on 12 Oct 2005 07:47:59 AM
The highliting of the row is written in JavaScript.
Did you mean the Color and the Border from the TopBar? If so, it can be changed in the CSS-Files.

My CRN-Version is: 1.1 MR2
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 12 Oct 2005 08:13:41 AM
Yep that's what I meant... But it still looks awsome!!
Title: Re: Showcase - Show your scripts working
Post by: jolly on 12 Oct 2005 08:20:01 AM
If you want to have these files, inform me.
Title: Re: Showcase - Show your scripts working
Post by: CoginAustin on 12 Oct 2005 10:42:54 AM
I would love to get a copy of them :)
Title: Re: Showcase - Show your scripts working
Post by: jolly on 12 Oct 2005 01:31:16 PM
And here are the CSS files. Please copy your original files and replace them by the new one. I included a readme with instructions where you can find these CSS-Files.

Have fun.

Cu
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 12 Oct 2005 02:00:24 PM
Tnx!!! I'm gonna take a look at them!
Title: Re: Showcase - Show your scripts working
Post by: JoeBass on 12 Oct 2005 02:13:05 PM
This Delphi snippet opens a browser and runs a report with a single parameter that the user chooses in the application.Ã,  The user is required to login to view the report.

//Open IE Code From - http://www.chami.com/tips/delphi/110396D.html
procedure TMainF.OpenInternetExplorer(sURL : string);
const
Ã,  csOLEObjName = 'InternetExplorer.Application';
var
Ã,  IEÃ,  Ã,  Ã,  Ã,  : Variant;
Ã,  WinHandle : HWnd;
begin
Ã,  if( VarIsEmpty( IE ) )then
Ã,  Ã,  begin
Ã,  Ã,  Ã,  IE := CreateOleObject( csOLEObjName );
Ã,  Ã,  Ã,  IE.Visible := true;
Ã,  Ã,  Ã,  IE.Navigate( sURL );
Ã,  Ã,  end
Ã,  else
Ã,  Ã,  begin
Ã,  Ã,  Ã,  WinHandle := FindWIndow( 'IEFrame', nil );
Ã,  Ã,  Ã,  if( 0 <> WinHandle )then
Ã,  Ã,  Ã,  Ã,  begin
Ã,  Ã,  Ã,  Ã,  Ã,  IE.Navigate( sURL );
Ã,  Ã,  Ã,  Ã,  Ã,  SetForegroundWindow( WinHandle );Ã,  Ã, 
Ã,  Ã,  Ã,  Ã,  end
Ã,  Ã,  Ã,  else
Ã,  Ã,  Ã,  Ã,  begin
Ã,  Ã,  Ã,  Ã,  Ã,  // handle error ...
Ã,  Ã,  Ã,  Ã,  end;
Ã,  Ã,  end;
end;

//Seeds from http://www.tek-tips.com
procedure TMainF.WithVendorMIClick(Sender: TObject);
begin
Ã,  if StartupCB.Text <> '' then
Ã,  Ã,  OpenInternetExplorer('http://www.yourserver.com/crn/cgi-bin/cognos.cgi?' +
Ã,  Ã,     'b_action=xts.run&m=portal/report-viewer.xts&method=' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, 'execute&m_obj=%2fcontent%2fpackage%5b%40name%3d%27' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, 'YourPackage%27%5d%2freport%5b%40name%3d%27' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, 'YourReport%27%5d&backURL=%2fcrn%2fcgi-bin' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, '%2fcognos.cgi%3fb_action%3dxts.run%26m%3dportal%2fcc.' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, 'xts%26m_path2%3d~%252ffolder%26m_path%3d%252fcontent%' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, '252fpackage%255b%2540name%253d%2527YourPackage%2527%255d'+
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, '&prompt=false' +
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã, '&YourParameterName=' + YourParameterValue);
end;
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 12 Oct 2005 02:33:29 PM
Tnx this will be very usefull!!
Maybe you could rewrite it to vbscript so most of the people can run and try it without having to compile it in Delphi?

But either way... Still very usefull... can't test it although  :'(
Title: Re: Showcase - Show your scripts working
Post by: jolly on 13 Oct 2005 01:22:43 AM
And here are the report specification for the highlited rows in a report. Be sure that you have the package GO Sales and Retailers in your CRN. You will find the javascript behind the "HTML Item".

Have fun
Title: Re: Showcase - Show your scripts working
Post by: jolly on 17 Oct 2005 05:16:22 AM
Okay, here is another one of my reports. In this report the user can change the row and the collumn. Also he can change the Measure. In the Prompt Page is a little Javascript which changes the first entry to a text of your choice. In the Report Page is another small Javascript which hide or show the Values/Params.

The attached File included four PNG where you can see the Report

Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 17 Oct 2005 06:03:51 AM
That really looks nice.. Now i'll have to try and top you :D
It's starting to look like a competition... :D
Maybe i've got time tonight to build a new one :D
Title: Re: Showcase - Show your scripts working
Post by: COGNOiSe administrator on 17 Oct 2005 08:02:11 AM
Nice work, jolly. Very nice.

Great topic RA!
Title: Re: Showcase - Show your scripts working
Post by: sir_jeroen on 17 Oct 2005 08:07:10 AM
Tnx...
Title: Re: Competition / Showcase - Show your scripts working
Post by: sir_jeroen on 17 Oct 2005 03:36:12 PM
Jolly I accepted your challenge and I raise you a:

Listitem with rowhighlighting and dynamic selection
Title: Re: Competition / Showcase - Show your scripts working
Post by: jolly on 18 Oct 2005 12:58:03 AM
Okay, I take a look at the new Tutorial. Thereafter now I am probably again to bild a new Report.  ;D
Title: Re: Competition / Showcase - Show your scripts working
Post by: sir_jeroen on 18 Oct 2005 01:10:00 AM
I always like competition.... :D Hopefully I can beat you..
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 24 Oct 2005 03:27:40 AM
Sorry for the delay to bild a new report. Look at the attached file. On the left side there is a simple List with Javascript inside.Ã,  On the right side is an Iframe which contains a Power Play Cube.
Title: Re: [Script] Some javascripts in actions
Post by: sir_jeroen on 24 Oct 2005 03:04:19 PM
Ok... I take this bet and I raise it this week... I'm still developing :D
Title: Re: [Script] Some javascripts in actions
Post by: jo0001 on 25 Oct 2005 04:40:45 AM
Hi,

I've just come across your site (COGNOiSe). Thanks a lot for all these cool tipps&tricks.

Therefore, I really would like to contribute some of mine.

Here is one of it. I called it TabView. Hope it is of anybody's interest:

<report xml:lang="de" xmlns="http://developer.cognos.com/schemas/report/1/"><!--RS:1.1-->
<modelConnection name="/content/package[@name='GO Sales and Retailers']/model[@name='model']"/>
<querySet xml:lang="de">
<BIQuery name="Abfrage1">
<cube><factList><item refItem="Retailer name" aggregate="none"/><item refItem="Order year" aggregate="none"/></factList></cube>
<tabularModel><dataItem name="Retailer name" aggregate="none"><expression>[gosales_goretailers].[Orders].[Retailer name]</expression></dataItem><dataItem name="Order year" aggregate="none"><expression>[gosales_goretailers].[Orders].[Order year]</expression></dataItem></tabularModel></BIQuery>
<BIQuery name="Abfrage2"><cube><factList><item refItem="Order year" aggregate="none"/></factList></cube><tabularModel><dataItem name="Order year" aggregate="none"><expression>[gosales_goretailers].[Orders].[Order year]</expression></dataItem></tabularModel></BIQuery><BIQuery name="Abfrage3"><cube><factList><item refItem="Quantity" aggregate="none"/></factList></cube><tabularModel><dataItem name="Quantity" aggregate="total"><expression>[gosales_goretailers].[Orders].[Quantity]</expression></dataItem></tabularModel></BIQuery></querySet>
<layoutList>
<layout>

<pageSet>

<page name="Seite1">
<pageBody>

<HTMLItem>
<HTML>&lt;table&gt;
     &lt;tr&gt;
          &lt;td class='mytab' onclick="swapTabs( 'tab1')"&gt;Tab 1&lt;/td&gt;
          &lt;td class='mytab' onclick="swapTabs( 'tab2')"&gt;Tab 2&lt;/td&gt;
          &lt;td class='mytab' onclick="swapTabs( 'tab3')"&gt;Tab 3&lt;/td&gt;
     &lt;/tr&gt;
&lt;/table&gt;
&lt;br&gt;
</HTML></HTMLItem>
<HTMLItem>
<HTML>&lt;span id='tab1' CLASS="DIV_DETAILS"&gt;</HTML></HTMLItem><block>
<list maxRows="1000" refQuery="Abfrage1" cellHeightBehavior="stretch">
<listColumnTitles><listColumnTitle><textItem><queryItemRef content="label" refItem="Retailer name"/></textItem></listColumnTitle><listColumnTitle><textItem><queryItemRef content="label" refItem="Order year"/></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn><textItem><queryItemRef refItem="Retailer name"/></textItem></listColumn><listColumn><textItem><queryItemRef refItem="Order year"/></textItem></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse"/>
</style>
<XMLAttribute name="RS_ListGroupInfo" value=""/></list>
</block>
<HTMLItem>
<HTML>&lt;/span&gt;</HTML></HTMLItem><HTMLItem>
<HTML>&lt;span id='tab2'&gt;
</HTML></HTMLItem><block>
<list refQuery="Abfrage2">
<listColumnTitles><listColumnTitle><textItem><queryItemRef content="label" refItem="Order year"/></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn><textItem><queryItemRef refItem="Order year"/></textItem></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse"/>
</style>
<XMLAttribute name="RS_ListGroupInfo" value=""/></list>

</block>
<HTMLItem>
<HTML>&lt;/span&gt;</HTML></HTMLItem><HTMLItem>
<HTML>&lt;span id='tab3'&gt;
</HTML></HTMLItem><block>
<list refQuery="Abfrage3">
<listColumnTitles><listColumnTitle><textItem><queryItemRef content="label" refItem="Quantity"/></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn><textItem><queryItemRef refItem="Quantity"/></textItem><style><CSS value="text-align:right"/></style></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse"/>
</style>
<XMLAttribute name="RS_ListGroupInfo" value=""/></list>

</block>
<HTMLItem>
<HTML>&lt;/span&gt;
&lt;img src="../pat/images/blank.gif" onload="swapTabs( 'tab1')"/&gt;</HTML></HTMLItem></pageBody>
<pageHeader>

<HTMLItem>
<HTML>&lt;style&gt;
.mytab{
     font-size:12px;
     font-weight:bold;
     color:black;
     border:1px solid black;
     cursor: hand;
}

&lt;/style&gt;

&lt;script&gt;

function swapTabs( tabId){

//alert(tabId);

var tab1 = document.getElementById("tab1");
var tab2 = document.getElementById("tab2");
var tab3 = document.getElementById("tab3");

      if (tabId=="tab1"){
     
tab1.style.display = "block";
tab2.style.display = "none";
tab3.style.display = "none";
}
else if(tabId=="tab2"){
     
      tab1.style.display = "none";
tab2.style.display = "block";
tab3.style.display = "none";
}
else if(tabId=="tab3"){

tab1.style.display = "none";
tab2.style.display = "none";
tab3.style.display = "block";
}
   
}

&lt;/script&gt;
</HTML></HTMLItem><block class="reportTitle">
<textItem class="reportTitleText">
<text/>
</textItem>
</block>
<style>
<CSS value="padding-bottom:10px"/>
</style>
</pageHeader>
<pageFooter>
<table>
<tableRow>
<tableCell>
<textItem>
<expression>AsOfDate()</expression>
</textItem>
<style>
<CSS value="vertical-align:top;text-align:left;width:25%"/>
</style>
</tableCell>
<tableCell>
<textItem>
<text>- </text>
</textItem>
<textItem>
<expression>PageNumber()</expression>
</textItem>
<textItem>
<text> -</text>
</textItem>
<style>
<CSS value="vertical-align:top;text-align:center;width:50%"/>
</style>
</tableCell>
<tableCell>
<textItem>
<expression>AsOfTime()</expression>
</textItem>
<style>
<CSS value="vertical-align:top;text-align:right;width:25%"/>
</style>
</tableCell>
</tableRow>
<style>
<CSS value="border-collapse:collapse;width:100%"/>
</style>
</table>
<style>
<CSS value="padding-top:10px"/>
</style>
</pageFooter>
</page></pageSet></layout>
</layoutList>
</report>

Cheers, Jochen
Title: Re: [Script] Some javascripts in actions
Post by: sir_jeroen on 25 Oct 2005 04:11:18 PM
Looks great... Are you in for some competition ? :D


2 little remarks:
Next time if possible add a screen dump and could you use the code-tag this because in some cases your code could get unescaped...(e.g. > becomes &gt; )


But still.. looks great!!
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 26 Oct 2005 02:20:54 AM
Hi jo0001,  8) 8)
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 26 Oct 2005 06:01:11 AM
Here is a small Video about another possibility to sort Columns with Javascript.
Title: Re: [Script] Some javascripts in actions
Post by: CoginAustin on 26 Oct 2005 06:50:54 AM
I cant play the file because of a "Unknown Codec" :(
Title: Re: [Script] Some javascripts in actions
Post by: sir_jeroen on 26 Oct 2005 07:20:25 AM
Jolly.... 1 word: AWSOME!!!
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 26 Oct 2005 07:48:22 AM
Okay, CoginAustin try this one. Sorry for the poor Quality.
Title: Re: [Script] Some javascripts in actions
Post by: CoginAustin on 26 Oct 2005 07:55:06 AM
Thanks! That is very cool
Title: Re: [Script] Some javascripts in actions
Post by: COGNOiSe administrator on 02 Nov 2005 08:21:57 AM
I had to restore the forum from backups earlier this week following the corruption of some forum software files and as such as attachments after 21st September will need to be uploaded again.

Apologies! I will try to do these backups more frequently (or if anyone knows how to run a CRON job to backup and save the database please drop me a line).

Cheers
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 21 Nov 2005 05:43:17 AM
It is already a time ago, which I built a report. In the attached File is a Video which shows an Template whith different Javascript Items inside. One of the Javascript Function is from ReportNet Addict. Btw. If you canÃ,´t play the file because of an "Unknown Codec", please go to the Techsmith Website and download the Codec. The Link http://www.techsmith.com/download/codecsdefault.asp.

Have fun

Cu Jolly
Title: Re: [Script] Some javascripts in actions
Post by: JoeBass on 21 Nov 2005 06:50:07 AM
That looks great Jolly. 

I've looked into your list sorting example and would like to be able to use your approach of clicking columns titles to sort. 

I don't expect you to reveal the code in your html item (your movie has a masterful tease that had me thinking you might show the innards) that does the work but, could you describe the method?  Thanks.
Title: Re: [Script] Some javascripts in actions
Post by: JoeBass on 21 Nov 2005 10:18:48 AM
Here's a simple list report based on Go Sales.Ã,  It is sortable by clicking column headers.Ã,  I pinched the amazing JavaScript table sorting code from Stuart Langridge at http://www.kryogenix.org/code/browser/sorttable/.Ã, 

--------------------------------------------------------------------------------------------
11/22 - Reworked the sort date function to work with short date formats.

<report xml:lang="en-us" xmlns="http://developer.cognos.com/schemas/report/1/"><!--RS:1.1-->
<layoutList>
<layout>

<pageSet>

<page name="Page1">
<pageBody><list id="List_ID" class="list" refQuery="Query1">
<listColumnTitles><listColumnTitle><textItem><queryItemRef content="label" refItem="Order number"/></textItem></listColumnTitle><listColumnTitle><textItem><queryItemRef content="label" refItem="Order method"/></textItem></listColumnTitle><listColumnTitle><textItem><queryItemRef content="label" refItem="Retailer name"/></textItem></listColumnTitle><listColumnTitle><textItem><queryItemRef content="label" refItem="Product name"/></textItem></listColumnTitle><listColumnTitle><textItem><queryItemRef content="label" refItem="Unit cost"/></textItem></listColumnTitle></listColumnTitles>
<listColumns><listColumn><textItem><queryItemRef refItem="Order number"/></textItem></listColumn><listColumn><textItem><queryItemRef refItem="Order method"/></textItem></listColumn><listColumn><textItem><queryItemRef refItem="Retailer name"/></textItem></listColumn><listColumn><textItem><queryItemRef refItem="Product name"/></textItem></listColumn><listColumn><textItem><queryItemRef refItem="Unit cost"/></textItem><style><CSS value="text-align:right"/></style></listColumn></listColumns>
<style>
<CSS value="border-collapse:collapse"/>
</style>
</list>
<HTMLItem>
<HTML>&lt;script&gt;
// Thank you Stuart Langridge!
// Javascript table sorting code from http://www.kryogenix.org/code/browser/sorttable/

addEvent(window, "load", sortables_init);

var SORT_COLUMN_INDEX;

function sortables_init() {
Ã,  Ã,  // Find all tables with class sortable and make them sortable
Ã,  Ã,  if (!document.getElementsByTagName) return;
Ã,  Ã,  tbls = document.getElementsByTagName("table");
Ã,  Ã,  for (ti=0;ti&lt;tbls.length;ti++) {
Ã,  Ã,  Ã,  Ã,  thisTbl = tbls[ti];
if (thisTbl.className == "list") {
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  ts_makeSortable(thisTbl);
Ã,  Ã,  Ã,  Ã,  }
Ã,  Ã,  }
}

function ts_makeSortable(table) {
Ã,  Ã,  if (table.rows &amp;&amp; table.rows.length &gt; 0) {
Ã,  Ã,  Ã,  Ã,  var firstRow = table.rows[0];
Ã,  Ã,  }
Ã,  Ã,  if (!firstRow) return;
Ã,  Ã, 
Ã,  Ã,  // We have a first row: assume it's the header, and make its contents clickable links
Ã,  Ã,  for (var i=0;i&lt;firstRow.cells.length;i++) {
Ã,  Ã,  Ã,  Ã,  var cell = firstRow.cells[i];
Ã,  Ã,  Ã,  Ã,  var txt = ts_getInnerText(cell);
Ã,  Ã,  Ã,  Ã,  cell.innerHTML = '&lt;a href="#" class="sortheader" onclick="ts_resortTable(this);return false;"&gt;'+txt+'&lt;span class="sortarrow"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/span&gt;&lt;/a&gt;';
Ã,  Ã,  }
}

function ts_getInnerText(el) {
if (typeof el == "string") return el;
if (typeof el == "undefined") { return el };
if (el.innerText) return el.innerText; //Not needed but it is faster
var str = "";

var cs = el.childNodes;
var l = cs.length;
for (var i = 0; i &lt; l; i++) {
switch (cs[i].nodeType) {
case 1: //ELEMENT_NODE
str += ts_getInnerText(cs[i]);
break;
case 3: //TEXT_NODE
str += cs[i].nodeValue;
break;
}
}
return str;
}

function ts_resortTable(lnk) {
Ã,  Ã,  // get the span
Ã,  Ã,  var span;
Ã,  Ã,  for (var ci=0;ci&lt;lnk.childNodes.length;ci++) {
Ã,  Ã,  Ã,  Ã,  if (lnk.childNodes[ci].tagName &amp;&amp; lnk.childNodes[ci].tagName.toLowerCase() == 'span') span = lnk.childNodes[ci];
Ã,  Ã,  }
Ã,  Ã,  var spantext = ts_getInnerText(span);
Ã,  Ã,  var td = lnk.parentNode;
Ã,  Ã,  var column = td.cellIndex;
Ã,  Ã,  var table = getParent(td,'TABLE');
Ã,  Ã, 
Ã,  Ã,  // Work out a type for the column
Ã,  Ã,  if (table.rows.length &lt;= 1) return;
Ã,  Ã,  var itm = ts_getInnerText(table.rows[1].cells[column]);
Ã,  Ã,  sortfn = ts_sort_caseinsensitive;
Ã,  Ã,  if (itm.match(/^\d\d[\/-]\d\d[\/-]\d\d\d\d$/)) sortfn = ts_sort_date;
Ã,  Ã,  if (itm.match(/^\d\d[\/-]\d\d[\/-]\d\d$/)) sortfn = ts_sort_date;
Ã,  Ã,  if (itm.match(/^[Ã,£$]/)) sortfn = ts_sort_currency;
Ã,  Ã,  if (itm.match(/^[\d\.]+$/)) sortfn = ts_sort_numeric;
Ã,  Ã,  SORT_COLUMN_INDEX = column;
Ã,  Ã,  var firstRow = new Array();
Ã,  Ã,  var newRows = new Array();
Ã,  Ã,  for (i=0;i&lt;table.rows[0].length;i++) { firstRow[i] = table.rows[0][i]; }
Ã,  Ã,  for (j=1;j&lt;table.rows.length;j++) { newRows[j-1] = table.rows[j]; }

Ã,  Ã,  newRows.sort(sortfn);

Ã,  Ã,  if (span.getAttribute("sortdir") == 'down') {
Ã,  Ã,  Ã,  Ã,  ARROW = '&amp;nbsp;&amp;nbsp;&amp;uarr;';
Ã,  Ã,  Ã,  Ã,  newRows.reverse();
Ã,  Ã,  Ã,  Ã,  span.setAttribute('sortdir','up');
Ã,  Ã,  } else {
Ã,  Ã,  Ã,  Ã,  ARROW = '&amp;nbsp;&amp;nbsp;&amp;darr;';
Ã,  Ã,  Ã,  Ã,  span.setAttribute('sortdir','down');
Ã,  Ã,  }
Ã,  Ã, 
Ã,  Ã,  // We appendChild rows that already exist to the tbody, so it moves them rather than creating new ones
Ã,  Ã,  // don't do sortbottom rows
Ã,  Ã,  for (i=0;i&lt;newRows.length;i++) { if (!newRows[i].className || (newRows[i].className &amp;&amp; (newRows[i].className.indexOf('sortbottom') == -1))) table.tBodies[0].appendChild(newRows[i]);}
Ã,  Ã,  // do sortbottom rows only
Ã,  Ã,  for (i=0;i&lt;newRows.length;i++) { if (newRows[i].className &amp;&amp; (newRows[i].className.indexOf('sortbottom') != -1)) table.tBodies[0].appendChild(newRows[i]);}
Ã,  Ã, 
Ã,  Ã,  // Delete any other arrows there may be showing
Ã,  Ã,  var allspans = document.getElementsByTagName("span");
Ã,  Ã,  for (var ci=0;ci&lt;allspans.length;ci++) {
Ã,  Ã,  Ã,  Ã,  if (allspans[ci].className == 'sortarrow') {
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  if (getParent(allspans[ci],"table") == getParent(lnk,"table")) { // in the same table as us?
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  allspans[ci].innerHTML = '&amp;nbsp;&amp;nbsp;&amp;nbsp;';
Ã,  Ã,  Ã,  Ã,  Ã,  Ã,  }
Ã,  Ã,  Ã,  Ã,  }
Ã,  Ã,  }
Ã,  Ã,  Ã,  Ã, 
Ã,  Ã,  span.innerHTML = ARROW;
}

function getParent(el, pTagName) {
if (el == null) return null;
else if (el.nodeType == 1 &amp;&amp; el.tagName.toLowerCase() == pTagName.toLowerCase()) // Gecko bug, supposed to be uppercase
return el;
else
return getParent(el.parentNode, pTagName);
}
function ts_sort_date(a,b) {

Ã,  Ã,  // y2k notes: two digit years less than 50 are treated as 20XX, greater than 50 are treated as 19XX
Ã,  Ã,  aa = ts_getInnerText(a.cells[SORT_COLUMN_INDEX]);
Ã,  Ã,  bb = ts_getInnerText(b.cells[SORT_COLUMN_INDEX]);

Ã,  Ã,  aaDateArray = aa.split("/");
Ã,  Ã,  bbDateArray = bb.split("/");

Ã,  Ã,  if (parseInt(aaDateArray[2]) < 50) { yr = '20'+ aaDateArray[2]; } else { yr = '19'+ aaDateArray[2]; }
Ã,  Ã,  if (parseInt(aaDateArray[0]) < 10) { TheMonth = '0' + aaDateArray[0]; } else { TheMonth = aaDateArray[0]; }
Ã,  Ã,  if (parseInt(aaDateArray[1]) < 10) { TheDay = '0' + aaDateArray[1]; } else { TheDay = aaDateArray[1]; }
Ã,  Ã,  dt1 = yr + TheMonth + TheDay;

Ã,  Ã,  if (parseInt(bbDateArray[2]) < 50) { yr = '20'+ bbDateArray[2]; } else { yr = '19'+ bbDateArray[2]; }
Ã,  Ã,  if (parseInt(bbDateArray[0]) < 10) { TheMonth = '0' + bbDateArray[0]; } else { TheMonth = bbDateArray[0]; }
Ã,  Ã,  if (parseInt(bbDateArray[1]) < 10) { TheDay = '0' + bbDateArray[1]; } else { TheDay = bbDateArray[1]; }
Ã,  Ã,  dt2 = yr + TheMonth + TheDay;

Ã,  Ã,  if (dt1==dt2) return 0;
Ã,  Ã,  if (dt1<dt2) return -1;
Ã,  Ã,  return 1;
}

function ts_sort_currency(a,b) {
Ã,  Ã,  aa = ts_getInnerText(a.cells[SORT_COLUMN_INDEX]).replace(/[^0-9.]/g,'');
Ã,  Ã,  bb = ts_getInnerText(b.cells[SORT_COLUMN_INDEX]).replace(/[^0-9.]/g,'');
Ã,  Ã,  return parseFloat(aa) - parseFloat(bb);
}

function ts_sort_numeric(a,b) {
Ã,  Ã,  aa = parseFloat(ts_getInnerText(a.cells[SORT_COLUMN_INDEX]));
Ã,  Ã,  if (isNaN(aa)) aa = 0;
Ã,  Ã,  bb = parseFloat(ts_getInnerText(b.cells[SORT_COLUMN_INDEX]));
Ã,  Ã,  if (isNaN(bb)) bb = 0;
Ã,  Ã,  return aa-bb;
}

function ts_sort_caseinsensitive(a,b) {
Ã,  Ã,  aa = ts_getInnerText(a.cells[SORT_COLUMN_INDEX]).toLowerCase();
Ã,  Ã,  bb = ts_getInnerText(b.cells[SORT_COLUMN_INDEX]).toLowerCase();
Ã,  Ã,  if (aa==bb) return 0;
Ã,  Ã,  if (aa&lt;bb) return -1;
Ã,  Ã,  return 1;
}

function ts_sort_default(a,b) {
Ã,  Ã,  aa = ts_getInnerText(a.cells[SORT_COLUMN_INDEX]);
Ã,  Ã,  bb = ts_getInnerText(b.cells[SORT_COLUMN_INDEX]);
Ã,  Ã,  if (aa==bb) return 0;
Ã,  Ã,  if (aa&lt;bb) return -1;
Ã,  Ã,  return 1;
}


function addEvent(elm, evType, fn, useCapture)
// addEvent and removeEvent
// cross-browser event handling for IE5+,Ã,  NS6 and Mozilla
// By Scott Andrew
{
Ã,  if (elm.addEventListener){
Ã,  Ã,  elm.addEventListener(evType, fn, useCapture);
Ã,  Ã,  return true;
Ã,  } else if (elm.attachEvent){
Ã,  Ã,  var r = elm.attachEvent("on"+evType, fn);
Ã,  Ã,  return r;
Ã,  } else {
Ã,  Ã,  alert("Handler could not be removed");
Ã,  }
}
&lt;/script&gt;</HTML></HTMLItem></pageBody>
</page></pageSet></layout>
</layoutList>
<modelConnection name="/content/package[@name='GO Sales and Retailers']/model[@name='model']"/><querySet xml:lang="en-us"><BIQuery name="Query1"><cube><factList><item refItem="Order number" aggregate="none"/><item refItem="Retailer name" aggregate="none"/><item refItem="Order date" aggregate="none"/><item refItem="Order method" aggregate="none"/><item refItem="Product name" aggregate="none"/><item refItem="Unit cost" aggregate="none"/></factList></cube><tabularModel><dataItem name="Order number" aggregate="none"><expression>[gosales_goretailers].[Orders].[Order number]</expression></dataItem><dataItem name="Retailer name" aggregate="none"><expression>[gosales_goretailers].[Orders].[Retailer name]</expression></dataItem><dataItem name="Order date" aggregate="none"><expression>[gosales_goretailers].[Orders].[Order date]</expression></dataItem><dataItem name="Order method" aggregate="none"><expression>[gosales_goretailers].[Orders].[Order method]</expression></dataItem><dataItem name="Product name" aggregate="none"><expression>[gosales_goretailers].[Orders].[Product name]</expression></dataItem><dataItem name="Unit cost" aggregate="average"><expression>[gosales_goretailers].[Orders].[Unit cost]</expression></dataItem></tabularModel></BIQuery></querySet></report>
Ã, 
Title: Re: [Script] Some javascripts in actions
Post by: sir_jeroen on 21 Nov 2005 01:49:10 PM
Nice... very nice code :D Always usefull...
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 21 Nov 2005 03:47:39 PM
Hi JoeBass,

here you got the Report specification about the sorting for Simple List Reports with Javascript.

Cu
Title: Re: [Script] Some javascripts in actions
Post by: JoeBass on 22 Nov 2005 08:29:16 AM
Thanks Jolly!  Very cool code.
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 25 Jan 2006 05:27:17 AM
ItÃ,´s time to show you a new Report IÃ,´ve built. In this Report I will show you a Drillthrough. But not the "normal" Drillthrough based on rows. I will show you a Drillthrough based on columns. The Video IÃ,´ve made is about 9 min. long a you can watch it at the following URL.

http://mitglied.lycos.de/jjolly/

Have fun.

Jolly
Title: Re: [Script] Some javascripts in actions
Post by: COGNOiSe administrator on 25 Jan 2006 06:34:43 AM
FAN-TASTIC!

Great work, Jolly! Mind if I put a little note on the home page?
Title: Re: [Script] Some javascripts in actions
Post by: jolly on 25 Jan 2006 06:56:17 AM
Thanks a lot. This Website is only a quick and dirty solution to share this video to all Cognoise Members. My first intention was that this Video is a great benefit for the Tutorial Site for Cognoise. But the Size of this Video is larger than 8 MB and the Webspace from the tutorialsite was reached. 

Jolly

Title: Re: [Script] Some javascripts in actions
Post by: COGNOiSe administrator on 25 Jan 2006 09:44:18 AM
I am happy to offer disk space and bandwidth on my server to anyone wanting to share such great animated tutorials with the community.

You will still have ownership and control - prob best if you somehow 'watermark' it or something.

Cheers
Jon
Title: Re: [Script] Some javascripts in actions
Post by: SueC on 25 Jan 2006 03:38:45 PM
WoW!

Thank you for taking the time to put that together!

Sue
Title: Re: [Script] Some javascripts in actions
Post by: JoeBass on 25 Jan 2006 03:48:18 PM
Bada**  It brought a tear to my eye. 
Title: Re: [Script] Some javascripts in actions
Post by: anoop_ind2 on 27 Jan 2006 01:26:00 AM
really wonderful scripts......... wud love to see more of it!! unfortunately i dont have winrar with me otherwise i wud have gotten to see more of jolly's work! in my office system i cant download or install winrar!! hope i wud get a workarnd for that in future though.......
Title: Re: [Script] Some javascripts in actions
Post by: srivaac on 03 May 2006 10:00:47 AM
I tried creating a ticket on http://www.jeroendegraaff.nl/cognoise ....but i keep on getting this message "Something went wrong. Please try again".

I would appreciated it if you help me out.

Thanks
Sri
Title: Re: [Script] Some javascripts in actions
Post by: praviin on 07 Sep 2006 06:30:48 AM
Hi All,

    I'm not able to download any of the attachments. I'm 404 - document not found error.
The topic looks very exciting and I want to check out the tricks with javascript. Can you all pls reattach the files
Title: Re: [Script] Some javascripts in actions
Post by: mrcool on 07 Sep 2006 06:45:42 AM
hi am unable 2 access the URL.....
Title: Re: [Script] Some javascripts in actions
Post by: jacon on 09 Jan 2007 01:58:04 AM
I am Unable to download any of the files or to view the url.
admin - can you help ?
10x in advanced..
Title: Re: [Script] Some javascripts in actions
Post by: COGNOiSe administrator on 31 May 2007 03:14:57 PM
Unfortunatelly, under former hosting provider, we've lost most attachments. RNA and others, would you be able to reupload?