<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Web Analytics Land &#187; s_code.js</title>
	<atom:link href="http://webanalyticsland.com/sitecatalyst-implementation/tag/s_codejs/feed/" rel="self" type="application/rss+xml" />
	<link>http://webanalyticsland.com</link>
	<description>Omniture SiteCatalyst Implementation Optimization.</description>
	<lastBuildDate>Sat, 19 Nov 2011 02:24:17 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>How To Capture A Query String Parameter From A Referring URL In SiteCatalyst</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/capture-query-string-parameter-from-referring-url/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/capture-query-string-parameter-from-referring-url/#comments</comments>
		<pubDate>Thu, 31 Mar 2011 02:13:42 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=617</guid>
		<description><![CDATA[Recently someone had asked the question, how do I capture a query string parameter that&#8217;s on referring URL? We all know how to grab a query string parameter from the current page URL by using the getQueryParam SiteCatalyst plug-in, but most people don&#8217;t know that plug-in can be used to get a query string parameter [...]]]></description>
			<content:encoded><![CDATA[<p>Recently someone had asked the question, <em>how do I capture a query string parameter that&#8217;s on referring URL?</em> We all know how to grab a query string parameter from the current page URL by using the <a href="http://webanalyticsland.com/sitecatalyst-plugins/getqueryparam/">getQueryParam SiteCatalyst plug-in</a>, but most people don&#8217;t know that plug-in can be used to get a query string parameter from the referring URL as well. I once had a real unique implementation that was not using that plug-in and needed to capture that value. I wanted to keep the implementation really light so I decided to give it a try using a smaller bit of code. I broke out a little JavaScript magic to see if I could make it happen simpler than using that plug-in. Turns out it&#8217;s not too difficult to accomplish, in fact I got it down to just a single line of code.<br />
</p>
<pre class="brush: jscript">
function getRefQueryParam(a){a=a.replace(/[\[]/,&quot;\\[&quot;).replace(/[\]]/,&quot;\\]&quot;);a=RegExp(&quot;[\\?&amp;]&quot;+a+&quot;=([^&amp;#]*)&quot;).exec(document.referrer);return a==null?&quot;&quot;:a[1]};
</pre>
<p>
Its a little function called getRefQueryParam. To use it just place that code in your s_code file, and then call it with the name of the query string parameter you want to capture. In this example I want to capture the value of the parameter forumID= from the referring URL and record it in s.prop1.<br />
</p>
<pre class="brush: jscript">
s.prop1=getRefQueryParam(&#039;forumID&#039;);
</pre>
<p>
With a little JavaScript goodness it is an easy value to capture.<br />
<br />
Enjoy.</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/capture-query-string-parameter-from-referring-url/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>How To Stop Google Preview From Being Counted In SiteCatalyst</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/how-to-stop-google-preview-from-being-counted-in-sitecatalyst/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/how-to-stop-google-preview-from-being-counted-in-sitecatalyst/#comments</comments>
		<pubDate>Wed, 17 Nov 2010 04:23:40 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[google]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[reports]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=451</guid>
		<description><![CDATA[Google Instant Preview, designed to show you a visual preview of your search results, rolled out in early November 2010. You now have the ability to click a small magnifying glass icon next to each search result to get a snapshot of what the page looks like.


Seems like a pretty helpful feature, but how do [...]]]></description>
			<content:encoded><![CDATA[<p>Google Instant Preview, designed to show you a visual preview of your search results, rolled out in early November 2010. You now have the ability to click a small magnifying glass icon next to each search result to get a snapshot of what the page looks like.<br />
<img src="http://webanalyticsland.com/images/google-preview.jpg" alt="Google Instant Preview" /><br />
<br />
Seems like a pretty helpful feature, but how do they do it? Well it would appear that Google has a new spider that crawls the web and takes snapshots of each page in its results. In order for them to get an accurate look at what the page looks like, this new bot needs to able to execute JavaScript. Here is the problem. Since it is executing JavaScript that means it is also firing off the SiteCatalyst code and is being counted as another visitor and is registering page views.<br />
<br />
How can you tell if this new Google Web Preview bot hit your site? If you are capturing User Agent you can see it show up in that report:<br />
<img src="http://webanalyticsland.com/images/user-agent-report.jpg" alt="User Agent Report" /><br />
<br />
<em><strong>NOTE: If you are not capturing user agent and would like to, a super simple way would be to use the <a href="http://blogs.omniture.com/2009/11/24/trimming-the-fat-with-dynamic-variables/">SiteCatalyst Dynamic Variable</a> functionality and include s.eVarX=&#8221;D=User-Agent&#8221;; in your s_code.js file. Just insert the number of the eVar you would like to use (a s.prop would work too) and you are all set.</strong></em><br />
<br />
Another way to see if you are being affected with spider traffic in your report suite from the Google Preview Bot would be to check out a Browser report (Visitor Profile > Technology > Browsers) and filter it to only show visitors using Safari 3.1 and then trend it.<br />
<img src="http://webanalyticsland.com/images/browser-report.jpg" alt="Browser Report" /><br />
We can see that this report suite has recorded about an additional 15,000 visitors over the last week that is just attributed to Safari 3.1. Checking the User Agent we saw earlier, the Google Web Preview bot is registering itself as Safari 3.1.<br />
<br />
Now that we can see that the Google Web Preview bot is having an effect on our traffic how do we get rid of it? We could block that bot in our robots.txt file, but I like having that additional functionality available for my visitors in the Google search results. I just don&#8217;t want it to execute my SiteCatalyst code. Well here is how to do it.<br />
<br />
I call this my <strong>bot detection code</strong> (real catchy title, right?). I currently have it just set to look for the Google Web Preview bot, but it could easily be modified to exclude other bots that can execute JavaScript. Here is how you implement it. In your s_code file, at the top you will have a s_account variable that contains your report suite id. It will look something like this:</p>
<pre class="brush: jscript">
var s_account=&quot;dead&quot;
</pre>
<p>To implement the bot detection code you will want to change that line to include the function call. It should look like this:</p>
<pre class="brush: jscript">
var s_account=botCheck(&quot;dead&quot;)
</pre>
<p>Pretty simple so far, right? We just added the function call and included our report suite id in it. Next we have a block of code that needs to be added to the plug-ins section of the s_code file:</p>
<pre class="brush: jscript">
function botCheck(b){var c=navigator.userAgent.toLowerCase(),a=&quot;&quot;;a+=c.indexOf(&quot;google web preview&quot;)!=-1?&quot;&quot;:b;return a};
</pre>
<p>And that&#8217;s all there is to it. So how does it work you ask? What it does is it removes your report suite id if it is the Google Web Preview bot that is accessing the page. The SiteCatalyst code will still fire off, but it will not include the report suite id so it will be discarded by SiteCatalyst and it will not affect your metrics.<br />
<br />
Want to see it in action? I thought you&#8217;d never ask! Check out the page <a href="http://webanalyticsland.com/test.php">http://webanalyticsland.com/test.php</a>. On this page I have a basic SiteCatalyst implementation, one line of code that displays your user agent, and then I print the results of the SiteCatalyst debugger right to the screen. Opening this page in a standard Firefox browser we can see that the SiteCatalyst code has fired off properly, it has displayed the correct user agent and the report suite id is contained within the image request string.<br />
<img src="http://webanalyticsland.com/images/testing1.jpg" alt="Test 1" target="_new" /><br />
So far so good. Using the <a href="https://addons.mozilla.org/en-US/firefox/addon/59/">User Agent switcher</a> plug-in for Firefox, we can switch out user agent to the one that we found in the SiteCatalyst report to mimic the Google Web Preview bot.<br />
<img src="http://webanalyticsland.com/images/testing2.jpg" alt="Test 2" /><br />
We can now see that when we use that bot&#8217;s user agent string, the report suite id is missing from the image request call. Any action that happens now will not be recorded in my report suite, and when SiteCatalyst receives this request it will be discarded. I&#8217;ve had this running for a few days now and have not found any issues, but since this is a pretty new chunk of code be sure to test it out before using it on your production site.<br />
<br />
Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/how-to-stop-google-preview-from-being-counted-in-sitecatalyst/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>Track HBX Style Links in SiteCatalyst</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/track-hbx-style-links-in-sitecatalyst/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/track-hbx-style-links-in-sitecatalyst/#comments</comments>
		<pubDate>Wed, 08 Sep 2010 20:44:40 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[HBX]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=398</guid>
		<description><![CDATA[I hear from a lot of people migrating from HBX to SiteCatalyst who are looking for ways to make that process a little easier. One of the hurdles I see is trying to migrate all of their HBX link tracking that is already in place to a format that SiteCatalyst can easily understand. That is [...]]]></description>
			<content:encoded><![CDATA[<p>I hear from a lot of people migrating from HBX to SiteCatalyst who are looking for ways to make that process a little easier. One of the hurdles I see is trying to migrate all of their HBX link tracking that is already in place to a format that SiteCatalyst can easily understand. That is an easy one to tackle. It&#8217;s called the setupLinkTrack plug-in.</p>
<p>Other than tracking all of you current HBX coded links, any SiteCatalyst user can get some benefit from it. Here is another great use for this plug-in. Recently I was reading a great article from <a href="http://twitter.com/adamgreco">@adamgreco</a> about <a href="http://www.the-omni-man.com/sitecatalyst/adamgreco/2010/08/23/tracking-navigation/">learning to track website navigation</a>. It is a really great article and if you have not had a chance to read it you should go check it out. In one part of the article Adam writes <em>&#8220;you should have your developer write code that will pass the name of the link to a Traffic Variable (sProp) when a visitor clicks on each link in your navigation&#8221;</em>. Well I&#8217;m the guy responsible for the tracking code for my website, so how can I track those links without adding a whole ton of JavaScript onclicks or some other server side hacks? This plug-in will easily handle that, without adding the extra server calls that come with the standard SiteCatalyst link tracking.</p>
<p>First take the plug-in code and add it to the plug-in section of your s_code.js file. Make sure you have the <a href="http://webanalyticsland.com/sitecatalyst-implementation/sitecatalyst-utility-functions/">utility functions</a> s.split and s.apl.</p>
<pre class="brush: jscript">
/*
 * Plugin: setupLinkTrack 2.0 - return links for HBX-based link
 *         tracking in SiteCatalyst (requires s.split and s.apl)
 */
s.setupLinkTrack=new Function(&quot;vl&quot;,&quot;c&quot;,&quot;&quot;
+&quot;var s=this;var l=s.d.links,cv,cva,vla,h,i,l,t,b,o,y,n,oc,d=&#039;&#039;;cv=s.&quot;
+&quot;c_r(c);if(vl&amp;&amp;cv!=&#039;&#039;){cva=s.split(cv,&#039;^^&#039;);vla=s.split(vl,&#039;,&#039;);for(&quot;
+&quot;x in vla)s._hbxm(vla[x])?s[vla[x]]=cva[x]:&#039;&#039;;}s.c_w(c,&#039;&#039;,0);if(!s.e&quot;
+&quot;o&amp;&amp;!s.lnk)return &#039;&#039;;o=s.eo?s.eo:s.lnk;y=s.ot(o);n=s.oid(o);if(s.eo&amp;&quot;
+&quot;&amp;o==s.eo){while(o&amp;&amp;!n&amp;&amp;y!=&#039;BODY&#039;){o=o.parentElement?o.parentElement&quot;
+&quot;:o.parentNode;if(!o)return &#039;&#039;;y=s.ot(o);n=s.oid(o);}for(i=0;i&lt;4;i++&quot;
+&quot;)if(o.tagName)if(o.tagName.toLowerCase()!=&#039;a&#039;)if(o.tagName.toLowerC&quot;
+&quot;ase()!=&#039;area&#039;)o=o.parentElement;}b=s._LN(o);o.lid=b[0];o.lpos=b[1];&quot;
+&quot;if(s.hbx_lt&amp;&amp;s.hbx_lt!=&#039;manual&#039;){if((o.tagName&amp;&amp;s._TL(o.tagName)==&#039;&quot;
+&quot;area&#039;)){if(!s._IL(o.lid)){if(o.parentNode){if(o.parentNode.name)o.l&quot;
+&quot;id=o.parentNode.name;else o.lid=o.parentNode.id}}if(!s._IL(o.lpos))&quot;
+&quot;o.lpos=o.coords}else{if(s._IL(o.lid)&lt;1)o.lid=s._LS(o.lid=o.text?o.t&quot;
+&quot;ext:o.innerText?o.innerText:&#039;&#039;);if(!s._IL(o.lid)||s._II(s._TL(o.lid&quot;
+&quot;),&#039;&lt;img&#039;)&gt;-1){h=&#039;&#039;+o.innerHTML;bu=s._TL(h);i=s._II(bu,&#039;&lt;img&#039;);if(bu&quot;
+&quot;&amp;&amp;i&gt;-1){eval(\&quot;__f=/ src\s*=\s*[\&#039;\\\&quot;]?([^\&#039;\\\&quot; ]+)[\&#039;\\\&quot;]?/i\&quot;)&quot;
+&quot;;__f.exec(h);if(RegExp.$1)h=RegExp.$1}o.lid=h}}}h=o.href?o.href:&#039;&#039;;&quot;
+&quot;i=h.indexOf(&#039;?&#039;);h=s.linkLeaveQueryString||i&lt;0?h:h.substring(0,i);l&quot;
+&quot;=s.linkName?s.linkName:s._hbxln(h);t=s.linkType?s.linkType.toLowerC&quot;
+&quot;ase():s.lt(h);oc=o.onclick?&#039;&#039;+o.onclick:&#039;&#039;;cv=s.pageName+&#039;^^&#039;+o.lid&quot;
+&quot;+&#039;^^&#039;+s.pageName+&#039; | &#039;+(o.lid=o.lid?o.lid:&#039;no &amp;lid&#039;)+&#039;^^&#039;+o.lpos;if&quot;
+&quot;(t&amp;&amp;(h||l)){cva=s.split(cv,&#039;^^&#039;);vla=s.split(vl,&#039;,&#039;);for(x in vla)s&quot;
+&quot;._hbxm(vla[x])?s[vla[x]]=cva[x]:&#039;&#039;;}else if(!t&amp;&amp;oc.indexOf(&#039;.tl(&#039;)&lt;&quot;
+&quot;0){s.c_w(c,cv,0);}else return &#039;&#039;&quot;);
s._IL=new Function(&quot;a&quot;,&quot;var s=this;return a!=&#039;undefined&#039;?a.length:0&quot;);
s._II=new Function(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;var s=this;return a.indexOf(b,c?c:0)&quot;);
s._IS=new Function(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;&quot;
+&quot;var s=this;return b&gt;s._IL(a)?&#039;&#039;:a.substring(b,c!=null?c:s._IL(a))&quot;);
s._LN=new Function(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;&quot;
+&quot;var s=this;b=a.href;b+=a.name?a.name:&#039;&#039;;c=s._LVP(b,&#039;lid&#039;);d=s._LVP(&quot;
+&quot;b,&#039;lpos&#039;);return[c,d]&quot;);
s._LVP=new Function(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;,&quot;&quot;
+&quot;var s=this;c=s._II(a,&#039;&amp;&#039;+b+&#039;=&#039;);c=c&lt;0?s._II(a,&#039;?&#039;+b+&#039;=&#039;):c;if(c&gt;-1)&quot;
+&quot;{d=s._II(a,&#039;&amp;&#039;,c+s._IL(b)+2);e=s._IS(a,c+s._IL(b)+2,d&gt;-1?d:s._IL(a)&quot;
+&quot;);return e}return &#039;&#039;&quot;);
s._LS=new Function(&quot;a&quot;,&quot;&quot;
+&quot;var s=this,b,c=100,d,e,f,g;b=(s._IL(a)&gt;c)?escape(s._IS(a,0,c)):esca&quot;
+&quot;pe(a);b=s._LSP(b,&#039;%0A&#039;,&#039;%20&#039;);b=s._LSP(b,&#039;%0D&#039;,&#039;%20&#039;);b=s._LSP(b,&#039;%&quot;
+&quot;09&#039;,&#039;%20&#039;);c=s._IP(b,&#039;%20&#039;);d=s._NA();e=0;for(f=0;f&lt;s._IL(c);f++){g&quot;
+&quot;=s._RP(c[f],&#039;%20&#039;,&#039;&#039;);if(s._IL(g)&gt;0){d[e++]=g}}b=d.join(&#039;%20&#039;);retu&quot;
+&quot;rn unescape(b)&quot;);
s._LSP=new Function(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;var s=this;d=s._IP(a,b);return d&quot;
+&quot;.join(c)&quot;);
s._IP=new Function(&quot;a&quot;,&quot;b&quot;,&quot;var s=this;return a.split(b)&quot;);
s._RP=new Function(&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;&quot;
+&quot;var s=this;d=s._II(a,b);if(d&gt;-1){a=s._RP(s._IS(a,0,d)+&#039;,&#039;+s._IS(a,d&quot;
+&quot;+s._IL(b),s._IL(a)),b,c)}return a&quot;);
s._TL=new Function(&quot;a&quot;,&quot;var s=this;return a.toLowerCase()&quot;);
s._NA=new Function(&quot;a&quot;,&quot;var s=this;return new Array(a?a:0)&quot;);
s._hbxm=new Function(&quot;m&quot;,&quot;var s=this;return (&#039;&#039;+m).indexOf(&#039;{&#039;)&lt;0&quot;);
s._hbxln=new Function(&quot;h&quot;,&quot;var s=this,n=s.linkNames;if(n)return s.pt(&quot;
+&quot;n,&#039;,&#039;,&#039;lnf&#039;,h);return &#039;&#039;&quot;);
</pre>
<p>Next in the s_doPlugins section of the s_code file you need a couple lines of setup.<br />
<strong><code><br />
s.hbx_lt = "auto" // manual, auto<br />
s.setupLinkTrack("prop1,prop2,prop3,prop4","SC_LINKS");<br />
</code></strong><br />
The plug-in will use 4 variables and a name for a cookie it will set. For this example I am going to use props 1 thru 4. </p>
<p>Next we have the actual code that will appear in the anchor tag that the plug-in will look for. It is a simple name attribute tag of <strong>lid</strong> and <strong>lpos</strong>. This is what a link would look like with the code properly formatted.<br />
<strong><code><br />
&lt;a href="my-page.php" name="&#038;lid=Featured Articles&#038;lpos=Left Nav"&gt;Cool Article Name&lt;/a&gt;<br />
</code></strong></p>
<p>Here&#8217;s what it will do. After clicking on a link that contains a lid and lpos (the exact link shown above), this is what you will find in the debugger on the page you land on:<br />
<img src="http://webanalyticsland.com/images/db1.jpg" alt="Debugger 1" /><br />
The plug-in entered the s.pageName value of the page that the click occurred into prop1, the value of lid into prop2, a combination of the prop1 and the value of lid into prop3 and the value of lpos in prop4. </p>
<p>Lets change up what we include in the actual link code. Lets remove the lid from the tag and just use this link:<br />
<strong><code><br />
&lt;a href="my-page.php" name="&#038;lpos=Left Nav"&gt;Cool Article Name&lt;/a&gt;<br />
</code></strong></p>
<p>This is what we will get from the debugger:<br />
<img src="http://webanalyticsland.com/images/db2.jpg" alt="Debugger 2" /><br />
You can see by not using the lid tag then the plug-in will use the actual anchor text in those positions.</p>
<p>Now lets say you are not interested in capturing the previous pageName value, or the combined previous pageName/lid value. You can just omit those variables in the plug-in setup. Change the code to:<br />
<strong><code><br />
s.hbx_lt = "auto" // manual, auto<br />
s.setupLinkTrack(",prop2,,prop4","SC_LINKS");<br />
</code><br />
</strong><br />
You can see I left the commas in there as empty place holders. Clicking the link with that setup and a lid and lpos value will return this in the debugger:<br />
<img src="http://webanalyticsland.com/images/db3.jpg" alt="Debugger 3" /></p>
<p>What about the other links on the page? What if they do not include a lid or lpos value? The plug-in will track those also. Clicking one of those links will return this in the debugger:<br />
<img src="http://webanalyticsland.com/images/db4.jpg" alt="Debugger 4" /><br />
The plug-in will still capture the previous pageName value, the anchor text and the combined values of the two.</p>
<p>I&#8217;m sure by now you noticed that auto/manual setting. Up to now its been set on auto. Let&#8217;s flip it to manual and click a link on the page that does not include any code. Here is what you will get:<br />
<img src="http://webanalyticsland.com/images/db5.jpg" alt="Debugger 5" /><br />
You will only get the two previous pageName values. If I would have omitted those two variables like I did earlier then it would have not returned anything. If you click on a link with a lid and lpos variables then  it will perform the same as if it were set to auto.</p>
<p>If you want to not add the code to the links so you can track all of the links on a page, but you only want to do it on a specific page and not the whole site you can then wrap the code in an if statement like this:<br />
<strong><code><br />
if(s.pageName=='Home'){<br />
s.hbx_lt = "auto" // manual, auto<br />
s.setupLinkTrack(",prop2,,prop4","SC_LINKS");<br />
}<br />
</code></strong><br />
You could also do that using document.location (or a million other ways to identify a specific page).</p>
<p>Since it also grabs the previous page value I no longer need the previous pageName plug-in (useful when using the getPercentPageViewed plug-in). </p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/track-hbx-style-links-in-sitecatalyst/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Implement Adobe SiteCatalyst in 5 Minutes (or less!)</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/implement-sitecatalyst-in-5-minutes/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/implement-sitecatalyst-in-5-minutes/#comments</comments>
		<pubDate>Thu, 19 Aug 2010 15:01:26 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=378</guid>
		<description><![CDATA[One of the biggest things I always hear from people considering moving to Adobe SiteCatalyst is the fear of a difficult implementation. It feels to me that most people think they need to implement everything at once, and that is not so. You can just take baby steps and implement small sections at a time. [...]]]></description>
			<content:encoded><![CDATA[<p>One of the biggest things I always hear from people considering moving to Adobe SiteCatalyst is the fear of a difficult implementation. It feels to me that most people think they need to implement everything at once, and that is not so. You can just take baby steps and implement small sections at a time. Let&#8217;s get started with just a standard implementation to get things going. I&#8217;m going to show you how to do a basic implementation of SiteCatalyst in 5 minutes. </p>
<p>First we need to set up a new report suite from the SiteCatalyst Admin Console Report Suite Manager. That can be found by selecting <strong>Admin > Report Suites</strong>.<br />
<img src="http://webanalyticsland.com/images/5min1.gif" alt="Admin Console" /><br />
Once we are in the Report Suite Manager, select <strong>Create New > Report Suite</strong>.<br />
<img src="http://webanalyticsland.com/images/5min2.gif" alt="Create New" /><br />
This will open up the New Report Suite setup page. On this page we have two sections to deal with, the first being where we can choose what type of site we are creating the report suite for. I recommend just leaving this set at the default suite type. Since we plan of adding some neat customizations in the future as our analytics needs increase, the default will work fine for us right now.<br />
<img src="http://webanalyticsland.com/images/5min3.gif" alt="Suite Type" /><br />
Next on this page we have five items that need to be filled in. They are all marked with red stars, with the most important being the first one, Report Suite ID. Why is this the most important? Because it the only one we cannot change later. I recommend it should be something you can easily understand what it means. If your site is apple.com then I would just simply choose <strong>apple</strong> and not something cryptic like <strong>89e7rghv9e7gh</strong> (yes I have seen that done before). It actually doesn&#8217;t matter what you choose (in case you had your heart set on using 89e7rghv9e7gh), anything will work, but choosing something simple may save some headaches in the future. The Site Title is what you want it to be referred to by in the SiteCatalyst interface, Time Zone is your time zone, Go Live Date is when the site is expected to launch (it must be a date in the future), and Estimated Page Views per Day is just what it says. This number is used by the Adobe engineers to determine what resources to dedicate to your site to ensure everything is recorded correctly. Remember any of these items (except Report Suite ID) can be changed later if you need to. There are other things listed here and you can fill them out or change them if you would like, they are not required in setting up the report suite. Fill out the five required fields, click submit and the report suite is created.<br />
<img src="http://webanalyticsland.com/images/5min4.gif" alt="Configure Suite" /><br />
There are some additional things we need to set up before we start with the actual data collection code. Head back to the Report Suite Manager and find you new suite in the list. Click it to highlight it and then mouse over the Edit Settings link. This will bring up a list of additional settings we can adjust. Remember this section. Later when you get more advanced with your SiteCatalyst data collection, this is where you will go to turn on and off variables for more advanced tracking. There are only two items we need to touch right now, and are going to be located under <strong>General</strong>. </p>
<p>Under Internal URL Filters you need to set what the domain of your site is. On every single page view there is a referrer. When your visitors go from your home page to your about us page, the referrer to that page is the home page. You do not want that showing up in your referrer reports, so this is where you list out the domain names that you do not want included in those reports. <strong>Quick tip:</strong> If your site is www.homes.com, and you enter <strong>homes.com</strong> in the URL filter, it will also filter out sites that have that name included in it, for example newhomes.com or cheaphomes.com. Add a period to the front of the domain name to make sure that only your site is filtered, <strong>.homes.com</strong>. You can also enter the subdomain with the URL in the filter if your site only lives at a single subdomain, or you can list all of them in the filter.<br />
<img src="http://webanalyticsland.com/images/5min5.gif" alt="Internal URL FIlter" /></p>
<p>Next you want to hit the Paid Search Detection. In here you need to set up a query sting parameter that will be used for your paid search. Even if you do not plan on doing paid search fill this out any way. It is important in making sure your Search Engine and Search Keywords reports work properly.<br />
<img src="http://webanalyticsland.com/images/5min6.gif" alt="Configure Suite" /></p>
<p>We created our report suite, filled out a handful of variables and we are now ready to start playing with the actual collection code. From the Admin Console Home you can find a direct link to the Code Manager, or you can find it from the navigation menu on the left.<br />
<img src="http://webanalyticsland.com/images/5min7.gif" alt="Admin Console Home" /></p>
<p>In the Code Manger we can generate all types of code for what ever we decide to track. From mobile phone apps to flash video players, all the collection code is here. We just want to generate the simple JavaScript Tracking code. Nothing fancy. Select your report suite, set your character encoding or your currency type and click <strong>Generate Code</strong>. You will get a little pop up warning you to make sure you know what you are doing or the world will end. Just click OK and move on.<br />
<img src="http://webanalyticsland.com/images/5min8.gif" alt="Code Manager" /></p>
<p>Your code is generated now. Take the contents that are under the <strong>Core Javascript File</strong> tab and save them in a file that you name <strong>s_code.js</strong>. Take that file and upload it to your web server where it can be accessed from every page of the site.<br />
<img src="http://webanalyticsland.com/images/5min9.gif" alt="Code Manager" /><br />
 Now take the contents under the <strong>Page Code</strong> tab and paste that to every page of your site, right before the closing body tag. In that code you will see the place marked <strong>INSERT-DOMAIN-AND-PATH-TO-CODE-HERE</strong>. In this position enter the path to the s_code.js file that you previously uploaded. </p>
<p>That&#8217;s all there is to it. This should be easily to be accomplished in 5 minutes or less. We setup the report suite, generated the page code and the s_code and added them to the site. This will give us the basic recording of the site traffic, referrals and visitor information. After this is up and running we can go back and add in some additional elements to the s_code file and the page code to customize your SiteCatalyst implementation to your specific site.</p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/implement-sitecatalyst-in-5-minutes/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Track Hash Query Parameters in Omniture SiteCatalyst</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/track-hash-query-parameters/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/track-hash-query-parameters/#comments</comments>
		<pubDate>Tue, 09 Feb 2010 04:50:13 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[getqueryparam]]></category>
		<category><![CDATA[hash]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=320</guid>
		<description><![CDATA[Do you have a site that uses a hash symbol in the URL with query parameters and you want a way to track them in SiteCatalyst? Well you have come to the right place. 
What am I talking about? Lets say you have a URL that looks like this:
http://webanalyticsland.com/#cid=Hash_Param_Test
and you want to capture the value [...]]]></description>
			<content:encoded><![CDATA[<p>Do you have a site that uses a hash symbol in the URL with query parameters and you want a way to track them in SiteCatalyst? Well you have come to the right place. </p>
<p>What am I talking about? Lets say you have a URL that looks like this:<br />
<a href="http://webanalyticsland.com/#cid=Hash_Param_Test">http://webanalyticsland.com/#cid=Hash_Param_Test</a><br />
and you want to capture the value of <strong>cid=</strong>. The standard getQueryParam plugin will not work in this case. It looks for a question mark in the URL, and as you can see this one did not have one.  </p>
<p>To capture this value we can use the <strong>getHashQueryParam</strong> s_code.js plug-in. What this plug-in does is looks for the hash symbol <strong>#</strong> at the end of the URL, then looks for the parameter you have listed in the function, then inserts the value in to the associated variable. This works just like the standard getQueryParam plugin, but looks for the hash instead.</p>
<p>Here&#8217;s how to use it. Insert this line of code in the s_doPlugins(s) section of your s_code.js file. Make sure you use the correct variable you want the metrics recorded in and which query string you want it to be associated with. I&#8217;m using <strong>s.prop17</strong> and <strong>cid</strong> in this example.</p>
<pre class="brush: jscript">
s.prop17=getHashQueryParam(&#039;cid&#039;);
</pre>
<p>Next enter this code in the plug-in&#8217;s section of your s_code file:</p>
<pre class="brush: jscript">
/*
 * Plugin: getHashQueryParam
 */
function getHashQueryParam(a){
var QueryString=window.location.search.substring(1);
if(QueryString==&#039;&#039;){var WinExtra=window.location.hash;
if(WinExtra.length &gt; 0){if(WinExtra.indexOf(a)&gt;-1){
QueryString=WinExtra.substr(WinExtra.indexOf(a))}}}
var returnValue=&#039;&#039;;var keyValPairs=QueryString.split(&#039;&amp;&#039;);
if(!keyValPairs){ keyValPairs = new Array();
keyValPairs[keyValPairs.length]=QueryString}
for(var counter=0;counter&lt;keyValPairs.length;counter++){
var keyVal=keyValPairs[counter].split(&#039;=&#039;);if(keyVal[0]==a){
returnValue=keyVal[1];break;}}return returnValue;}
</pre>
<p><a href="http://webanalyticsland.com/#cid=Hash_Param_Test">Here is an example of it live in action.</a> After you click on the link, open the debugger you will see the value entered in s.prop17.</p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/track-hash-query-parameters/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Don&#8217;t Forget Your SiteCatalyst Utility Functions!</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/sitecatalyst-utility-functions/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/sitecatalyst-utility-functions/#comments</comments>
		<pubDate>Wed, 06 Jan 2010 15:56:48 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[enhancements]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=314</guid>
		<description><![CDATA[Have you ever tried to use a new plug-in and found it did not work? You were probably missing a utility function. Utility functions are designed to work with SiteCatalyst plug-ins. There are 6 utility functions that are commonly used. They are apl, p_c, p_gh, split, replace, and join.
These functions do things like join elements [...]]]></description>
			<content:encoded><![CDATA[<p>Have you ever tried to use a new plug-in and found it did not work? You were probably missing a utility function. Utility functions are designed to work with SiteCatalyst plug-ins. There are 6 utility functions that are commonly used. They are <strong>apl</strong>, <strong>p_c</strong>, <strong>p_gh</strong>, <strong>split</strong>, <strong>replace</strong>, and <strong>join</strong>.</p>
<p>These functions do things like join elements of an array into a string delimiter by a string, replaces characters in a string, splits a string on a specific character, append a value to any delimited lists, and more. THese utility functions are referenced by several standard plug-ins.</p>
<p>Here&#8217;s how I do it. I take all these utility functions and wrap them all up in one neat package, and include this as one of my standard plug-ins to add when creating a s_code file. This way not thing is missed, nothing is forgotten and all of my plug-ins will work no problem.</p>
<p>Here&#8217;s what it looks like:</p>
<pre class="brush: jscript">
/*
 * Utility Functions: apl, p_c, p_gh, split, replace, join
 */
s.apl=new Function(&quot;L&quot;,&quot;v&quot;,&quot;d&quot;,&quot;u&quot;,&quot;&quot;
+&quot;var s=this,m=0;if(!L)L=&#039;&#039;;if(u){var i,n,a=s.split(L,d);for(i=0;i&lt;a.&quot;
+&quot;length;i++){n=a[i];m=m||(u==1?(n==v):(n.toLowerCase()==v.toLowerCas&quot;
+&quot;e()));}}if(!m)L=L?L+d+v:v;return L&quot;);
s.p_c=new Function(&quot;v&quot;,&quot;c&quot;,&quot;&quot;
+&quot;var x=v.indexOf(&#039;=&#039;);return c.toLowerCase()==v.substring(0,x&lt;0?v.le&quot;
+&quot;ngth:x).toLowerCase()?v:0&quot;);
s.p_gh=new Function(&quot;&quot;
+&quot;var s=this;if(!s.eo&amp;&amp;!s.lnk)return &#039;&#039;;var o=s.eo?s.eo:s.lnk,y=s.ot(&quot;
+&quot;o),n=s.oid(o),x=o.s_oidt;if(s.eo&amp;&amp;o==s.eo){while(o&amp;&amp;!n&amp;&amp;y!=&#039;BODY&#039;){&quot;
+&quot;o=o.parentElement?o.parentElement:o.parentNode;if(!o)return &#039;&#039;;y=s.&quot;
+&quot;ot(o);n=s.oid(o);x=o.s_oidt}}return o.href?o.href:&#039;&#039;;&quot;);
s.split=new Function(&quot;l&quot;,&quot;d&quot;,&quot;&quot;
+&quot;var i,x=0,a=new Array;while(l){i=l.indexOf(d);i=i&gt;-1?i:l.length;a[x&quot;
+&quot;++]=l.substring(0,i);l=l.substring(i+d.length);}return a&quot;);
s.repl=new Function(&quot;x&quot;,&quot;o&quot;,&quot;n&quot;,&quot;&quot;
+&quot;var i=x.indexOf(o),l=n.length;while(x&amp;&amp;i&gt;=0){x=x.substring(0,i)+n+x.&quot;
+&quot;substring(i+o.length);i=x.indexOf(o,i+l)}return x&quot;);
s.join = new Function(&quot;v&quot;,&quot;p&quot;,&quot;&quot;
+&quot;var s = this;var f,b,d,w;if(p){f=p.front?p.front:&#039;&#039;;b=p.back?p.back&quot;
+&quot;:&#039;&#039;;d=p.delim?p.delim:&#039;&#039;;w=p.wrap?p.wrap:&#039;&#039;;}var str=&#039;&#039;;for(var x=0&quot;
+&quot;;x&lt;v.length;x++){if(typeof(v[x])==&#039;object&#039; )str+=s.join( v[x],p);el&quot;
+&quot;se str+=w+v[x]+w;if(x&lt;v.length-1)str+=d;}return f+str+b;&quot;);
</pre>
<p>I just make sure that is block is included in every s_code file. Then I am assured that every plug-in I use can find the correct utility function it needs to work properly.</p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/sitecatalyst-utility-functions/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Track Your Visitors Copied Text With SiteCatalyst Plug-in</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/track-copied-text-plugin/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/track-copied-text-plugin/#comments</comments>
		<pubDate>Mon, 21 Dec 2009 11:00:56 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[enhancements]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[visitors]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=295</guid>
		<description><![CDATA[To me Web Analytics is the science of analyzing visitor behavior in order to improve the Web Site for the purpose of increasing conversion. Anytime I can use web analytics to help the visitor find what they are looking for, I feel I&#8217;m doing my job. But lets say your visitors are finding what they [...]]]></description>
			<content:encoded><![CDATA[<p>To me Web Analytics is the science of analyzing visitor behavior in order to improve the Web Site for the purpose of increasing conversion. Anytime I can use web analytics to help the visitor find what they are looking for, I feel I&#8217;m doing my job. But lets say your visitors are finding what they are looking for, but it is just not as easy as it could be? How would I know?</p>
<p>One thing I have been playing with is to monitor what content my visitors are selecting and copying from the site. If I see a lot of visitors copying my email address, maybe I should make the contact form a little easier to be found. If I see a lot of copying of some sample code, maybe I should make it easier to download it, or include a pdf copy. But how do I find out how to capture what my visitors copy? Here you go. </p>
<p>This is all done by adding a plug-in and a bit of code to the s_code file. This code looks for any time some text is copied and sets it in a prop and fires an event. This will work if the visitor highlights text and goes the right click/copy route, or by hitting Control/Command + C. You will need either 1 eVar and 1 event, or a 1 prop to use. If you want to go the eVar and event route, take this code and place it some where BEFORE the <strong>function s_doPlugins(s)</strong> call: </p>
<pre class="brush: jscript">
var eventAttached=false;
if(!eventAttached){eventAttached = true;
function trackCopy(){
var overrides = {&#039;events&#039;:&#039;event8&#039;,&#039;eVar18&#039;:getCopiedText()};
	s.templtv=s.linkTrackVars;
	s.templte=s.linkTrackEvents;
   	s.linkTrackVars=&#039;eVar18,events&#039;;
	s.linkTrackEvents=s.events=&#039;event8&#039;;
	s.tl(true, &#039;o&#039;, &#039;Text Copied&#039;, overrides);
	if(s.templtv) s.linkTrackVars=s.templtv;
	if(s.templte) s.linkTrackEvents=s.templte;
}
</pre>
<p>Insert the eVar and event you are going to use where you see them in the code. If you decide to just use a single prop instead, then use this bit of code, again before the <strong>function s_doPlugins(s)</strong> call: </p>
<pre class="brush: jscript">
var eventAttached=false;
if(!eventAttached){eventAttached = true;
function trackCopy(){
var overrides = {&#039;prop49&#039;:getCopiedText()};
	s.templtv=s.linkTrackVars;
   	s.linkTrackVars=&#039;prop49&#039;;
	s.tl(true, &#039;o&#039;, &#039;Text Copied&#039;, overrides);
	if(s.templtv) s.linkTrackVars=s.templtv;
}
</pre>
<p>Insert the prop you want to use where you see it set. Next take this code and put it in the plug-in&#8217;s section of the s_code file:</p>
<pre class="brush: jscript">
function getCopiedText() {
if (document.selection){return document.selection.createRange().text;}
else if (window.getSelection){return window.getSelection();}return &#039;&#039;;}
if(document.body &amp;&amp; document.body.attachEvent){
document.body.attachEvent(&quot;oncopy&quot;, trackCopy);}
else if (document.body &amp;&amp; document.body.addEventListener){
document.body.addEventListener(&#039;copy&#039;,trackCopy, false);}}
</pre>
<p>What are we going to end up with? You will get a report that looks like this:<br />
<img src="http://webanalyticsland.com/images/copied-text.png" alt="Copied Text Report" /></p>
<p>It&#8217;s pretty interesting to see what your visitors are choosing to copy. Now do I expect to find huge some game changing incite that will lead me to make a change to the Web Site that will increase my conversion rate 100% with this report? Probably not. Do I expect to find one more place that allows me to make another 1% improvement? I sure do. Remember, all those 1% improvements add up. <img src='http://webanalyticsland.com/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>Big thanks to <strong>kgs/ksmith</strong> in the Omniture Developer Connection for the original idea to do this.</p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/track-copied-text-plugin/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Additional Methods To Measure Interaction Using The Get Time To Complete Plug-In</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/additional-methods-to-measure-interaction-using-the-get-time-to-complete-plug-in/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/additional-methods-to-measure-interaction-using-the-get-time-to-complete-plug-in/#comments</comments>
		<pubDate>Fri, 11 Dec 2009 15:58:54 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[cookies]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>
		<category><![CDATA[visitors]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=284</guid>
		<description><![CDATA[Recently there was a great article on the Omniture Blog all about Capturing Time Spent on . . . well, just about anything. It&#8217;s a great post and definitely worth checking out. After reading it I was wondering if there was another way to do it? Of course there is! I present the Time To [...]]]></description>
			<content:encoded><![CDATA[<p>Recently there was a great article on the Omniture Blog all about <a href="http://blogs.omniture.com/2009/12/10/time-spent-interacting-with-just-about-anything/">Capturing Time Spent on . . . well, just about anything</a>. It&#8217;s a great post and definitely worth checking out. After reading it I was wondering if there was another way to do it? Of course there is! I present the Time To Complete Plug-in. </p>
<p>The getTimeToComplete plug-in will track the time it takes a user to complete some process on your site. The &#8220;clock&#8221; begins when you call the plug-in with the value &#8220;start&#8221; and stops when the plug-in with the value &#8220;stop&#8221;. The plug-in can be used to track the time to complete a checkout process, to track the time to complete an application process, to track the time a user spends viewing/using Rich Internet Applications (RIA), or to track the time between a download and a purchase.</p>
<pre class="brush: jscript">
s.getTimeToComplete( v, cn, e )
</pre>
<p>v is the Value &#8211; &#8216;start&#8217; or &#8216;stop&#8217;<br />
cn is the Cookie Name – example: &#8216;ttc&#8217;<br />
e is the Expiration &#8211; days to expiration of the cookie, 0 for session<br />
This function will return an empty string &#8221; or a value in days, hours, minutes or seconds</p>
<p>There is a bunch of different ways to use this plug-in. I like this first method because you do not have to add a single of code to the page to make it work (I have found it is much easier to get a development team to simply upload a new s_code file as opposed to adding additional code to the site.) Lets say you want to track a form on your site. Lets say the form is at /my-form.php. Once the visitor fills out the form, they are taken to the thank you page which lets say is at /my-form-thanks.php. I would add this bit of code to the s_code file:</p>
<pre class="brush: jscript">
if (window.location.pathname==&#039;/my-form.php&#039;) s.ttc=&#039;start&#039;;
if (window.location.pathname==&#039;/my-form-thanks.php&#039;) s.ttc=&#039;stop&#039;;
s.prop1=s.getTimeToComplete(s.ttc,&#039;ttc&#039;,0);
</pre>
<p>What this does is looks for the path in the URL for /my-form.php and sets <strong>start</strong> in s.ttc. When the plug-in see&#8217;s this it set&#8217;s the cookie <strong>ttc</strong> with a start time Then when the URL path is /my-form-thanks.php <strong>stop</strong> is set. When the plug-in see&#8217;s <strong>stop</strong>, it then reads the <strong>ttc</strong> plug-in and records the time difference in s.prop1. The time value that you will get will have days and hours rounded to .2 (e.g. 1.4 days), minutes to .5 (e.g. 2.5 minutes), and seconds to 5 (e.g. 15 seconds).</p>
<p><strong>NOTE:</strong>When this is implemented, if you check the debugger you will not see any value for s.prop1 until you have reached the stop point of the process.</p>
<p>Here is another way to use the code. Let&#8217;s say you have some events set right on the pages of your site. We want to know how long it takes to get from when event1 is set to when event2 is set. I would add this code into the s_code file:</p>
<pre class="brush: jscript">
if(s.events.indexOf(&#039;event1&#039;)&gt;-1) s.ttc=&#039;start&#039;;
if(s.events.indexOf(&#039;event2&#039;)&gt;-1) s.ttc=&#039;stop&#039;;
s.prop1=s.getTimeToComplete(s.ttc,&#039;ttc&#039;,0);
</pre>
<p>What this does is look for when event1 happens, then set <strong>start</strong> in s.ttc. When event2 happens <strong>stop</strong> is set, and the time value is set in s.prop1.</p>
<p><strong>NOTE:</strong> Another thing to remember is this can be used to record the time of many different processes or paths on your site. If you do that I suggest using a different cookie name and variable value in each one so there are no issues.</p>
<p>Here is the actual plug-in code:<br />
The getTimeToComplete plug-in returns the time to complete a task. When v is &#8216;start&#8217; a cookie is written with the timestamp. When v is &#8216;stop&#8217; the cookie is read and the expired time is returned in days, hours, minutes, or seconds.</p>
<pre class="brush: jscript">
/*
 * Plugin: getTimeToComplete
 */
s.getTimeToComplete=new Function(&quot;v&quot;,&quot;cn&quot;,&quot;e&quot;,&quot;&quot;
+&quot;var s=this,d=new Date,x=d,k;if(!s.ttcr){e=e?e:0;if(v==&#039;start&#039;||v==&#039;&quot;
+&quot;stop&#039;)s.ttcr=1;x.setTime(x.getTime()+e*86400000);if(v==&#039;start&#039;){s.c&quot;
+&quot;_w(cn,d.getTime(),e?x:0);return &#039;&#039;;}if(v==&#039;stop&#039;){k=s.c_r(cn);if(!s&quot;
+&quot;.c_w(cn,&#039;&#039;,d)||!k)return &#039;&#039;;v=(d.getTime()-k)/1000;var td=86400,th=&quot;
+&quot;3600,tm=60,r=5,u,un;if(v&gt;td){u=td;un=&#039;days&#039;;}else if(v&gt;th){u=th;un=&quot;
+&quot;&#039;hours&#039;;}else if(v&gt;tm){r=2;u=tm;un=&#039;minutes&#039;;}else{r=.2;u=1;un=&#039;sec&quot;
+&quot;onds&#039;;}v=v*r/u;return (Math.round(v)/r)+&#039; &#039;+un;}}return &#039;&#039;;&quot;);
</pre>
<p>I really like this plug-in because you end up with a report that is completely dedicated to the time it takes to complete that exact action. </p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/additional-methods-to-measure-interaction-using-the-get-time-to-complete-plug-in/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Enhance Your SiteCatalyst S_Code Using Server-Side Scripting</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/enhance-your-sitecatalyst-s_code-using-server-side-scripting/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/enhance-your-sitecatalyst-s_code-using-server-side-scripting/#comments</comments>
		<pubDate>Tue, 08 Dec 2009 03:13:23 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[enhancements]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=273</guid>
		<description><![CDATA[I receive a lot of questions from people working on their own SiteCatalyst implementations and I&#8217;m always happy to help. One that I got recently is &#8220;why is your s_code file a php file&#8221;? I figured there were not too many people out there doing it like this or even know about this, so I [...]]]></description>
			<content:encoded><![CDATA[<p>I receive a lot of questions from people working on their own SiteCatalyst implementations and I&#8217;m always happy to help. One that I got recently is &#8220;why is your s_code file a php file&#8221;? I figured there were not too many people out there doing it like this or even know about this, so I thought I would help out those that were interested in what the advantages of using server side code to enhance your data collection.</p>
<p>The reason I use a php file to house all of my s_code script is simple. I want to be able to do what is not easily done with using standard JavaScript. Here are a couple of examples.</p>
<p>First things first. How do I get a php file to act like JavaScript? It&#8217;s actually pretty easy. First thing you do is in the top of your file add this small bit of code:</p>
<pre class="brush: php">
&lt;?php header(&#039;Content-type: application/javascript&#039;); ?&gt;
</pre>
<p>The purpose of this line is just to say &#8216;hey, unless instructed otherwise, treat everything you are going to see here as JavaScript. Next change your file extension from .js to .php. That&#8217;s all you need to do to start adding in some php scripting into your file.</p>
<p>Here are some things I am using it for. I like capturing the IP address of my visitors. I like to track this because I have had problems with spammers, scraper bots and general bad visitors in the past, and I just like keeping my eye on things. Here is the code to capture IP address.</p>
<pre class="brush: php">
s.eVar17=&quot;&lt;?php echo $_SERVER[&#039;REMOTE_ADDR&#039;]?&gt;&quot;;
</pre>
<p>I also have this matched with the <a href="http://webanalyticsland.com/plugins/Get_Val_Once_Plugin.pdf">get Val Once</a> plug-in. </p>
<p>Another thing I like to capture is User Agent. How many people come to my site from a specific build of IE6? Is Googlebot executing my JavaScript when crawling my site? Here is how I capture User Agent.</p>
<pre class="brush: php">
s.eVar23=&quot;&lt;?php echo $_SERVER[&#039;HTTP_USER_AGENT&#039;]?&gt;&quot;;
</pre>
<p>Again I match this up with the get Val Once plug-in.</p>
<p>Another thing I like to do is use php to populate the configuration variables of the Time Parting plug-in. The latest version of the plug-in, 2.0, uses specific daylight savings time variables (the 2.0 version is available from the Omniture Help section. The version I host here on the site is the older 1.4 version). The 3 variables that need to be configured for the plug-in are Daylight Savings Time start day for the current year, Daylight Savings Time end day for the current year, and the Current Year. Now all of these can be hard coded, but I&#8217;d rather do a little bit of one time coding and never have to worry about it again. Here is how I set those variables using php.</p>
<pre class="brush: php">
s.dstStart=&quot;&lt;?php echo date(&#039;m/d/Y&#039;, strtotime(&quot;Second Sunday March 0&quot;));?&gt;&quot;;
s.dstEnd=&quot;&lt;?php echo date(&#039;m/d/Y&#039;, strtotime(&quot;First Sunday November 0&quot;));?&gt;&quot;;
s.currentYear=&quot;&lt;?php echo date(&#039;Y&#039;);?&gt;&quot;;
</pre>
<p>All of these take advantage of the date() functionality of php. Combine that with a little bit of extra code, and with the fact that I know that daylight savings time always begins the second Sunday of March and ends on the first Sunday of November, I never need to touch those variables again.</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/enhance-your-sitecatalyst-s_code-using-server-side-scripting/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The getCartOpen and resetGetCartOpen SiteCatalyst Plugins</title>
		<link>http://webanalyticsland.com/sitecatalyst-implementation/the-getcartopen-and-resetgetcartopen-sitecatalyst-plugins/</link>
		<comments>http://webanalyticsland.com/sitecatalyst-implementation/the-getcartopen-and-resetgetcartopen-sitecatalyst-plugins/#comments</comments>
		<pubDate>Tue, 13 Oct 2009 03:07:26 +0000</pubDate>
		<dc:creator>VaBeachKevin</dc:creator>
				<category><![CDATA[SiteCatalyst Implementation]]></category>
		<category><![CDATA[code]]></category>
		<category><![CDATA[ecommerce tracking]]></category>
		<category><![CDATA[implementation]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[omniture]]></category>
		<category><![CDATA[plugin]]></category>
		<category><![CDATA[shopping cart]]></category>
		<category><![CDATA[sitecatalyst]]></category>
		<category><![CDATA[s_code.js]]></category>
		<category><![CDATA[tracking]]></category>

		<guid isPermaLink="false">http://webanalyticsland.com/?p=239</guid>
		<description><![CDATA[In our quest to make our SiteCatalyst implementation more powerful and lighten the load on the developers and programmers (who for some reason always have more important things to do then add more Omniture code to the site), there are a couple of plug-ins I like to use to help to set the scOpen event.
The [...]]]></description>
			<content:encoded><![CDATA[<p>In our quest to make our SiteCatalyst implementation more powerful and lighten the load on the developers and programmers (who for some reason always have more important things to do then add more Omniture code to the site), there are a couple of plug-ins I like to use to help to set the scOpen event.</p>
<p>The scOpen event is used to populate the Carts Report and metric with the number of times visitors view a new shopping cart during an eCommerce process. The scAdd event should be used when adding items into a shopping cart. But what if every time you add an item to the shopping cart, you are taken to the shopping cart? Well then you should set both events the first time. But only first time the shopping cart is opened, the scOpen event should be set. If the shopping cart has already been opened, the scOpen event should not be set again during that visit. So how do we make sure that the scOpen event is only set on that very first instance of the cart being viewed?</p>
<p>What we have here are the <strong>getCartOpen</strong> and <strong>resetGetCartOpen</strong> SiteCatalyst plug-ins. What the getCartOpen plug-in does is looks for the very first instance of the scAdd event being set and adds the scOpen event at that same time. Each time after that the scAdd event is set, the scOpen event will not be set again. But what if the visitor completes an order and wants to place another during the same visit? That&#8217;s where the resetGetCartOpen plug-in comes in. It looks for an instance of the purchase event and then allows the scOpen event to be set again if a new shopping cart is created.</p>
<p>This first line which goes in the calls to plugins section of the s_code.js file, calls the getCartOpen plugin and returns the events string with scOpen added the first time scAdd occurs during a visit.</p>
<pre class="brush: jscript">
/*Get Cart Open*/
s.events=s.getCartOpen(&quot;s_scOpen&quot;);
</pre>
<p>And here is the getCartOpen plug-in code that should be added to the plug-in code section.</p>
<pre class="brush: jscript">
/*
 * Plugin: getCartOpen
 */
s.getCartOpen=new Function(&quot;c&quot;,&quot;&quot;
+&quot;var s=this,t=new Date,e=s.events?s.events:&#039;&#039;,i=0;t.setTime(t.getTim&quot;
+&quot;e()+1800000);if(s.c_r(c)||e.indexOf(&#039;scOpen&#039;)&gt;-1){if(!s.c_w(c,1,t))&quot;
+&quot;{s.c_w(c,1,0)}}else{if(e.indexOf(&#039;scAdd&#039;)&gt;-1){if(s.c_w(c,1,t)){i=1}&quot;
+&quot;else if(s.c_w(c,1,0)){i=1}}}if(i){e=e+&#039;,scOpen&#039;}return e&quot;);
</pre>
<p>This line which goes in the calls to plug-ins section of the s_code.js file, calls the resetGetCartOpen plug-in and resets the scOpen event after a purchase takes place, allowing the scOpen event to be set again if the visitor decides to make another purchase during the same visit.</p>
<pre class="brush: jscript">
/*Reset Get Cart Open*/
s.events=s.resetGetCartOpen();
</pre>
<p>And here is the resetGetCartOpen plug-in code that should be added to the plug-in code section.</p>
<pre class="brush: jscript">
/*
 * Plugin: resetGetCartOpen
 */
s.resetGetCartOpen=new Function(&quot;&quot;
+&quot;var s=this,t=new Date,e=s.events?s.events:&#039;&#039;;t.setTime(t.getTime()+&quot;
+&quot;10000);if(e.indexOf(&#039;purchase&#039;)&gt;-1){if(s.c_r(&#039;s_scOpen&#039;)||e.indexOf&quot;
+&quot;(&#039;scOpen&#039;)&gt;-1){if(!s.c_w(&#039;s_scOpen&#039;,&#039;&#039;,t)){s.c_w(&#039;s_scOpen&#039;,&#039;&#039;,0);}&quot;
+&quot;}}return e&quot;);
</pre>
<p>For more information on when to use the scOpen and scAdd events, check out the Omniture Knowledge base Answer ID 440.</p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://webanalyticsland.com/sitecatalyst-implementation/the-getcartopen-and-resetgetcartopen-sitecatalyst-plugins/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>

