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
:o OK... tell me how you did that world map! :o
It's very impressive! All done with sdk or script?
No sdk used at all... only javascript... :D
Took some time... but got it finally working....
Tnx for the compliment...
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 :)
Yeah right... ;)
Show it :P
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>'<iframe src="http://www.google.com/maps?q=' || Replace ([Address line 1], ' ', '+') || '+' || Trim([Postal zone])|| Trim('"')|| ' name="SetIFrame" ' || 'style=" width:610px; height:450px" /></iframe>'
</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>
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 :)
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!!
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..
yes it does... that's how it works for me :D
RN A, Your clickable map report looks great. Can you show the source? Thanks.
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.
you can contact me using msn chat... See my profile for details...
and to make you curious: it's data driven :D
My interest is piqued! I would like to follow up but, I will be away from the PC for some time. Thank you.
Just as I'd like to have you :P
Really good. And here is one of my Reports. Small but helpfull for the Users.(//). The Event onMouseOver highlited the complete row.
Cu Jolly
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??
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
Yep that's what I meant... But it still looks awsome!!
If you want to have these files, inform me.
I would love to get a copy of them :)
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
Tnx!!! I'm gonna take a look at them!
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;
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 :'(
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
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
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
Nice work, jolly. Very nice.
Great topic RA!
Tnx...
Jolly I accepted your challenge and I raise you a:
Listitem with rowhighlighting and dynamic selection
Okay, I take a look at the new Tutorial. Thereafter now I am probably again to bild a new Report. ;D
I always like competition.... :D Hopefully I can beat you..
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.
Ok... I take this bet and I raise it this week... I'm still developing :D
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><table>
<tr>
<td class='mytab' onclick="swapTabs( 'tab1')">Tab 1</td>
<td class='mytab' onclick="swapTabs( 'tab2')">Tab 2</td>
<td class='mytab' onclick="swapTabs( 'tab3')">Tab 3</td>
</tr>
</table>
<br>
</HTML></HTMLItem>
<HTMLItem>
<HTML><span id='tab1' CLASS="DIV_DETAILS"></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></span></HTML></HTMLItem><HTMLItem>
<HTML><span id='tab2'>
</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></span></HTML></HTMLItem><HTMLItem>
<HTML><span id='tab3'>
</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></span>
<img src="../pat/images/blank.gif" onload="swapTabs( 'tab1')"/></HTML></HTMLItem></pageBody>
<pageHeader>
<HTMLItem>
<HTML><style>
.mytab{
font-size:12px;
font-weight:bold;
color:black;
border:1px solid black;
cursor: hand;
}
</style>
<script>
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";
}
}
</script>
</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
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 > )
But still.. looks great!!
Hi jo0001, 8) 8)
Here is a small Video about another possibility to sort Columns with Javascript.
I cant play the file because of a "Unknown Codec" :(
Jolly.... 1 word: AWSOME!!!
Okay, CoginAustin try this one. Sorry for the poor Quality.
Thanks! That is very cool
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
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
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.
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><script>
// 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<tbls.length;ti++) {
Ã, Ã, Ã, Ã, thisTbl = tbls[ti];
if (thisTbl.className == "list") {
Ã, Ã, Ã, Ã, Ã, Ã, ts_makeSortable(thisTbl);
Ã, Ã, Ã, Ã, }
Ã, Ã, }
}
function ts_makeSortable(table) {
Ã, Ã, if (table.rows && table.rows.length > 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<firstRow.cells.length;i++) {
Ã, Ã, Ã, Ã, var cell = firstRow.cells[i];
Ã, Ã, Ã, Ã, var txt = ts_getInnerText(cell);
Ã, Ã, Ã, Ã, cell.innerHTML = '<a href="#" class="sortheader" onclick="ts_resortTable(this);return false;">'+txt+'<span class="sortarrow">&nbsp;&nbsp;&nbsp;</span></a>';
Ã, Ã, }
}
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 < 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<lnk.childNodes.length;ci++) {
Ã, Ã, Ã, Ã, if (lnk.childNodes[ci].tagName && 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 <= 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<table.rows[0].length;i++) { firstRow[i] = table.rows[0][i]; }
Ã, Ã, for (j=1;j<table.rows.length;j++) { newRows[j-1] = table.rows[j]; }
Ã, Ã, newRows.sort(sortfn);
Ã, Ã, if (span.getAttribute("sortdir") == 'down') {
Ã, Ã, Ã, Ã, ARROW = '&nbsp;&nbsp;&uarr;';
Ã, Ã, Ã, Ã, newRows.reverse();
Ã, Ã, Ã, Ã, span.setAttribute('sortdir','up');
Ã, Ã, } else {
Ã, Ã, Ã, Ã, ARROW = '&nbsp;&nbsp;&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<newRows.length;i++) { if (!newRows[i].className || (newRows[i].className && (newRows[i].className.indexOf('sortbottom') == -1))) table.tBodies[0].appendChild(newRows[i]);}
Ã, Ã, // do sortbottom rows only
Ã, Ã, for (i=0;i<newRows.length;i++) { if (newRows[i].className && (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<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 = '&nbsp;&nbsp;&nbsp;';
Ã, Ã, Ã, Ã, Ã, Ã, }
Ã, Ã, Ã, Ã, }
Ã, Ã, }
Ã, Ã, Ã, Ã,Â
Ã, Ã, span.innerHTML = ARROW;
}
function getParent(el, pTagName) {
if (el == null) return null;
else if (el.nodeType == 1 && 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<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<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");
Ã, }
}
</script></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>
Ã,Â
Nice... very nice code :D Always usefull...
Hi JoeBass,
here you got the Report specification about the sorting for Simple List Reports with Javascript.
Cu
Thanks Jolly! Very cool code.
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
FAN-TASTIC!
Great work, Jolly! Mind if I put a little note on the home page?
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
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
WoW!
Thank you for taking the time to put that together!
Sue
Bada** It brought a tear to my eye.
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.......
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
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
hi am unable 2 access the URL.....
I am Unable to download any of the files or to view the url.
admin - can you help ?
10x in advanced..
Unfortunatelly, under former hosting provider, we've lost most attachments. RNA and others, would you be able to reupload?