<script>var
viewReq = new Array();function vu(u) {var i=new
Image();i.src=u.replace("&","&");viewReq.push(i);}</script><script>vu("https://securepubads.g.doubleclick.net/pcs/view?xai\u003dAKAOjssl4JCDRnjsbCyNPe8LkpYjlCK9hlyS8wNZjDIFZSxMJPoUnynkNavlky9xgTEo6hqec4lm0i5qphICLfFhui6-azWf0jas1xfkS3pvcmt81TXBL32hbpvprXNNmOiDRGK2kEFPXeZcMR7whRn0Nlr7QvwPkdzYxBJWGttESZJeZPm-L61i1T0xaJNXQPQoU0rTLwRkOUPwACp7_0X2lXEEcqSxKo3Bi3-astjdGOskORaWFzZ6aEKZeXHaYJlbrnDd5qmorXE1szU\u0026sai\u003dAMfl-YQP0AAjQ6ReAH2fnZQbbSjHYFA37UAB9r5ALoaSy-gTklGNoY_RZ3lRaiIky1nltxj7vqu3W3tzvgZyp4nbxyJoOK3FhslhlURdSVO49E-R3Bv-NUhlDv77d5A\u0026sig\u003dCg0ArKJSzPqWMDiRTEE3EAE\u0026urlfix\u003d1\u0026adurl\u003d")</script><script
src="https://rev.cbsi.com/common/js/adKit.min.js?348392305"></script>
<script>
var
win = (top!=self && "techrepublic.com"!="") ? window.top :
window;
var cbsAds = window.top.cbsAds || new adKit(win);
// define View behavior
// name identifies the view constructor
// buildView returns the view object
cbsAds.Views.push({
name: "dynamic_showcase",
// pass util as reference to access methods
buildView: function(type, pos, targeting, doc, par, frame, util,
stylesheet){
var timestamp = new Date().getTime();
var adNetwork = par.id.indexOf("/8264")!=-1 ? "8264" : "7336";
var adUnit =
par.id.substring(par.id.indexOf("/"+adNetwork)+adNetwork.length,
par.id.lastIndexOf("_"));
var subcreativeParWrapId = 'subcreativeParWrap_'+timestamp;
var view = {
"type": type,
"pos": pos,
"targeting": targeting,
"stylesheet": stylesheet,
"ad_built": false,
"ad_building": false,
"callback_array": []
};
// DOM interaction when ad is first initialized
view.initRender = function(){
cbsAds.testLog("initRender", true, "Init Render Called");
// frame behavior
if(frame){
frame.style.display = "none";
par.style.height = "auto";
// inline behavior
}else{
if(par){par.style.height = "auto";}
}
};
// DOM interaction to build container
view.containerRender = function(){
cbsAds.testLog("containerRender", true, "Container Render Called");
// load optional css
if(this.stylesheet){ util.loadCSS(this.stylesheet); }
// condense reference
var el = util.addEl;
var docfrag = doc.createDocumentFragment();
// dynamic vars based on ad unit
var brandCopy="Premier Brands on CNET";
if(adUnit.indexOf("es-cnet")>=0){ brandCopy="Marcas de Primera en
CNET"; }
if(adUnit.indexOf("techrepublic")>=0 ||
adUnit.indexOf("zdnet")>=0){ brandCopy="Featured Content"; }
// addEl function parameters & types: el = string, tar = element,
att = obj, textnode = string, innerHTML=string
// att must be formal attributes, example: { class: "class1", id:
"id1", width: 500, height: 65 }
var div_container = el("div", docfrag, {
"id" : "ads_dynamicShowcase"
}, "","<h5><span>"+brandCopy+"</span></h5>");
var subcreativeParWrap = el("div", div_container, {
"id": subcreativeParWrapId
});
var ul_list = el("ul", subcreativeParWrap, {
"id": "dynamicShowcase_ul"
});
par.appendChild(docfrag);
this.ad_built=true;
this.ad_building=false;
for(var i=0, l=this.callback_array.length;i<l;i++){
this.subcreativeRender(this.callback_array.shift());
}
};
// DOM interaction to build subcreative
view.subcreativeRender = function(ad_obj){
cbsAds.testLog("subcreativeRender", true, "Subcreative Render
Called");
// condense reference
var el = util.addEl;
var docfrag = doc.createDocumentFragment();
// addEl function parameters & types: el = string, tar = element,
att = obj, textnode = string, innerHTML=string
// att must be formal attributes, example: { class: "class1", id:
"id1", width: 500, height: 65 }
var seat_li = el("li", docfrag, {
"class": "dynamicShowcase_li",
'data-ad-track':'1',
'data-ad-cid':ad_obj.cid,
'data-ad-pos':'top',
'data-ad-sid':par.parentNode.id
});
var seat_link = el("a", seat_li, {
"href": ad_obj.clickURL,
"target": "_blank",
"rel": "nofollow"
}, '','<figure><img class="dynamicShowcase_image"
src="'+ad_obj.mainProductImage+'" style="width:170px; height:96px;"
/></figure><div class="dynamicShowcase_text"><span
class="dynamicShowcase_headline">'+ad_obj.mainHeadline+'</span><span
class="dynamicShowcase_copy">'+ad_obj.mainCopy+'</span></div>');
// only write out the expand portion if the optional "Expand
Headline" input has a value
if(ad_obj.expandHeadline != ""){
var seat_expandWrap = el("div", seat_li, {
"class": "dynamicShowcase_expandWrap"
}, '', '<span
class="dynamicShowcase_expandWrap_headline">'+ad_obj.expandHeadline+'</span><span
class="dynamicShowcase_expandWrap_copy">'+ad_obj.expandCopy+'</span><a
href="'+ad_obj.clickURL+'" target="_blank"
class="dynamicShowcase_expandWrap_action">'+ad_obj.expandCalltoAction+'</a>');
}
doc.getElementById(subcreativeParWrapId).firstChild.appendChild(docfrag);
// ref = reference to cbsAds object
if(window.cbsAds){
var ref = window.cbsAds;
}else if(window.parent && window.parent.cbsAds){
var ref = window.parent.cbsAds;
}else if(window.top && window.top.cbsAds){
var ref = window.top.cbsAds;
}else{
var ref = null;
}
};
return view;
}
});
// uncomment the following line to launch the test module
//cbsAds.testSetup();
// uncomment the following line to use test subcreatives using the test
subcreative below
//cbsAds.testSubs = true;
// this is a test subcreative that you'll have to update with the
relevant placeholders (using Info Button placeholders as example)
// these will be used in the subcreativeRender function
cbsAds.testSubcreativeObject = {
clickURL: "http://www.cnet.com",
mainProductImage: "https://rev.cbsi.com/common/60x45.jpg",
mainHeadline: "headline",
mainCopy: "copy",
expandHeadline: "expand headline",
expandCopy: "expand copy",
expandCalltoAction: "Visit Showcase"
};
cbsAds.testLog("setup", cbsAds.win===window, "Window is Top");
// this is the guts of the container creative (using Info Button values
as example)
// initAd object nodes & types: type = string, subcreative_size =
array, max_seats = integer, seat_overides = object, test_network =
string, pos = string, stylesheet = string
// seat_overides must be formal attributes, example: [{
adUnit:"phones",seats:3 },{ adUnit:"tablets",seats:2 }]
cbsAds.initAd({
type: "dynamic_showcase",
subcreative_size: [372,142],
max_seats: 2,
seat_overides: [],
test_network: "/7336/aw-cnet",
pos: "",
targeting:{ "campaign":"", "env":"prod", "session":"g", "subses":"6",
"ptype":"article", "vguid":"6c3b4316-1c68-4944-a3ec-9059a76698da" },
stylesheet: ""
});
ads_logger('Dynamic Showcase Center container ::: creative id =
83651727249');
function ads_logger(str){try{console.log(str);}catch(e){}};
// no warnings!
// var nowarn =
https://adclick.g.doubleclick.net/pcs/click?xai=AKAOjstyzbENLkr75f-qwhTPtxMSllObbGVmWdj_nRFTEFKA1miZfvMblZ1rT_5phUH90t2hUDC4Fe5xiTqcxZVP4pZ8X1OLkONrCbLFoW5tV6SO2AOEelVfmiOR3xGkLh55ixDPW50v4RkYoqBDFogWCg3l8ODVILnPHM3yu_vkxie2sBPG34X-g4DuKODxwksrFZ35_gZ3hTESnEnziy1fUB8gjaCT_Ybq8s3uvXROsK-QqKBoD2-IXKu6oWP9P7hWLxBChXk&sai=AMfl-YRmb3-L5qtbmOseDv22NApeXfX3xdL8JQ4cXoW7kFxTV2JJJtecJ4t1CLetZE5dUyGG6LBFL4kI-o-uM1_EZs3Gq5f0hUVrR6Ntm4vTGsw5mZ_l0F7FTF1vDPE&sig=Cg0ArKJSzHgK0FJsU71WEAE&urlfix=1&adurl=;
</script>
<script
src="https://tpc.googlesyndication.com/pagead/js/r20180507/r20110914/activeview/osd_listener.js"></script><script
type="text/javascript">osdlfm(-1,'','B2d7kmkn1WseTK8KZywWhxJGIBwAAAAAQATgByAEJwAIC4AIA4AQBoAYf0ggFCIAhEAE','',2081490876,true,'mraid_race\u0026ud\u003d1\u0026la\u003d1\u0026alp\u003dxai\u0026alh\u003d3341779805\u0026',3,'CAASEuRo0445ZV6qStSjQkF8Imbp-Q','https://pagead2.googlesyndication.com/pcs/activeview?xai\u003dAKAOjsvbNNSb5aR9s7valha18BHEIqwZnMPB48tgQLCy-XnYI80SBYJYwqo0PAdcBahzJo0Ayxax-HdX8Oo7PNQQmDUXH5y4ttv_4Kg\u0026sig\u003dCg0ArKJSzM0ZwCk6j2GwEAE','');</script><script>if
(window.top && window.top.postMessage)
{window.top.postMessage('{"googMsgType":"adpnt"}','*');}</script><div
style="bottom:0;right:0;width:371px;height:771px;background:initial
!important;position:absolute !important;max-width:100%
!important;max-height:100% !important;pointer-events:none
!important;image-rendering:-moz-crisp-edges
!important;z-index:2147483647;background-image:url('')
!important"></div>