Professional Documents
Culture Documents
scribd.Document = function() {
//Private vars this.__params = [ ]; this.__callQueue = [ ]; (FILO) this.__listenerLookup = { }; callback2:Function ... ] // document attributes // stores premature method calls for later replay, technically a stack
if (arguments.length == 2) { // This option is included for backwards compatibility only! this.document_id = arguments[0]; this.access_key = arguments[1]; return this; }
if (scribd.Document.caller != scribd.Document.getDoc && scribd.Document.caller != scribd.Document.getDocFromUrl && scribd.Document.caller != scribd.Document.getDocFromUrlForExtension && scribd.Document.caller != undefined ) { throw new Error("There is no public constructor for scribd.Document."); } }
scribd.Document.getDoc = function(document_id, access_key) { scribd_doc = new scribd.Document(); scribd_doc.document_id = document_id; scribd_doc.access_key = access_key; return scribd_doc; }
scribd.Document.getDocFromUrl = function(url, publisher_id) { scribd_doc = new scribd.Document(); scribd_doc.url = url; scribd_doc.publisher_id = publisher_id; return scribd_doc; }
scribd.Document.prototype = { /* ---------------
Private Methods
Note: Routed events are those which get routed through a globally defined method: window._scribd_event_handler_embedName() We define this method to allow message passing between iPaper and this particular scribd.Document instance. Only used for browsers which don't adhere to the DOM 2 event specification (IE).
Workflow: 1) Assign window._scribd_event_handler_embedName = this.__handleEvent, in this.write() 2) Add any event listeners to this.__listenerLookup 3) iPaper calls window._scribd_event_handler_embedName to trigger events, which get routed back through to this.__handleEvent 4) Iterate through __listenerLookup, firing the appropriate callbacks
----------------- */
if (this.__listenerLookup[ eventType ]){ this.__listenerLookup[ eventType ].push(callback); } else { this.__listenerLookup[ eventType ] = new Array( callback ); } },
__removeRoutedListener: function( eventType, callback ){ var listeners = this.__listenerLookup[ eventType ]; for (var i=0; i<listeners.length; i++ ){ if( listeners[i] == callback ){
listeners.splice(i, 1); } } },
__listenerExists: function( eventType, callback ){ var listeners = this.__listenerLookup[ eventType ] || []; for ( var i=0; i<listeners.length; i++ ){ if (listeners[i] == callback) return true; } return false; },
addEventListener: function( eventType, callback, optBubble ){ if (this.api){ if (window.addEventListener){ this.api.parentNode.addEventListener( eventType, callback, false ); } else { this.__addRoutedListener( eventType, callback ); }
removeEventListener: function( eventType, callback ){ if (this.api){ if (window.addEventListener){ this.api.removeEventListener( eventType, callback, false ); } else { this.__removeRoutedListener( eventType, callback ); } } else { this.__callQueue.push(["removeEventListener", eventType, callback]); } },
grantAccess : function(user_identifier, secure_session_id, signature) { this.__params["user_identifier"] = user_identifier; this.__params["secure_session_id"] = secure_session_id; this.__params["signature"] = signature; },
if (quickswitch) { // create container at body level to avoid calling innerHTML on an element with an inline ancestor var container = document.createElement('div'); container.style.width = "100%"; container.style.height = "100%"; document.body.appendChild(container); }
var auto_width = element.offsetWidth; var view_mode = ''; var flashVars = ''; if (this.__params["width"] && this.__params["width"] != "parent") { auto_width = this.__params["width"]; } if (this.__params["mode"]){
if (this.__params["height"] != "parent") { var auto_height = Math.round(auto_width * 11.0 / 8.5) if (view_mode == 'slideshow') { auto_height = 35 + Math.round(auto_width * 3.0 / 4.0); }
// Get height of page var page_height = window.innerHeight != null ? window.innerHeight : document.documentElement && document.documentElement.clientHeight ? document.documentElement.clientHeight : document.body != null ? document.body.clientHeight : 0;
var embedWidth = "100%"; var embedName = elementId + '_embed' + Math.round(Math.random() * 9e9); this.__embedName = embedName; var srcString = "ScribdViewer";
// This defaults to true so we only need to handle explicit false cases if (this.__params["auto_size"] != true){ flashVars += '&auto_size=false'; }
if (this.__params["height"] && this.__params["height"] != "parent"){ embedHeight = this.__params["height"] + "px"; } if (this.__params["width"] && this.__params["width"] != "parent"){ embedWidth = this.__params["width"] + "px";
if (this.__params["disable_related_docs"]){ flashVars += '&disable_related_docs=' + this.__params["disable_related_docs"]; } if (this.__params["page"]){ flashVars += '&page=' + this.__params["page"]; } if (this.__params["extension"]){ flashVars += '&extension=' + this.__params["extension"]; } if (this.__params["title"]){ flashVars += '&title=' + escape(this.__params["title"]); } if (this.__params["my_user_id"]){ flashVars += '&my_user_id=' + this.__params["my_user_id"]; } if (this.__params["api_url"]){ flashVars += '&api_url=' + this.__params["api_url"]; }
if (this.__params["doctype"]){ flashVars += '&doctype=' + this.__params["doctype"]; } if (this.__params["current_user_id"]){ flashVars += '¤t_user_id=' + this.__params["current_user_id"]; } if (this.__params["search_query"]){ flashVars += '&search_query=' + escape(this.__params["search_query"]); } if (this.__params["search_keywords"]){ flashVars += '&search_keywords=' + escape(this.__params["search_keywords"]); } if (this.__params["transferCookie"]==true){ flashVars += '&cookie=' + escape(document.cookie); } if (this.__params["should_redirect"]){ flashVars += '&should_redirect=' + this.__params["should_redirect"]; } if (this.__params["secret_password"]){ flashVars += '&secret_password=' + this.__params["secret_password"]; } if (this.__params["public"] == true){ flashVars += '&privacy=0'; } else {
flashVars += '&privacy=1'; }
if (this.__params["user_identifier"]) { flashVars += '&user_identifier=' + escape(this.__params["user_identifier"]); } if (this.__params["secure_session_id"]) { flashVars += '&secure_session_id=' + escape(this.__params["secure_session_id"]); } if (this.__params["signature"]) { flashVars += '&signature=' + this.__params["signature"]; } if (this.__params["docinfo"]) { //need to use encodeURIComponent for '+' and '/' in base64 encoding flashVars += '&docinfo=' + encodeURIComponent(this.__params["docinfo"]); } if (this.__params["useIntegratedUi"]) { flashVars += '&useIntegratedUi=' + this.__params["useIntegratedUi"]; }
} if (this.access_key){ flashVars += '&access_key=' + this.access_key; } if (this.extension_id){ flashVars += '&extension_id=' + this.extension_id; } if (this.url){ flashVars += '&url=' + escape(this.url); } if (this.publisher_id){ flashVars += '&publisher_id=' + escape(this.publisher_id); }
var embedString = Scribd_AC_RunActiveContent.Mod_AC_FL_RunContent( 'codebase', protocol + 'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0', 'width', embedWidth, 'height', embedHeight, 'flashvars', flashVars, 'src', srcPath + srcString, 'quality', 'high', 'pluginspage', protocol + 'www.macromedia.com/go/getflashplayer', 'align', 'middle', 'play', 'true', 'loop', 'true', 'scale','showall', 'wmode', 'opaque', 'devicefont', 'false', 'id',embedName, 'bgcolor', '#ffffff', 'name', embedName, 'menu','true', 'allowFullScreen', 'true', 'allowScriptAccess','always', 'movie', srcPath + srcString,
'salign','');
var flash_ok = Scribd_AC_RunActiveContent.DetectFlashVer(9,0,0); if (!flash_ok) { embedString = '<div style="font-size:16px;width:300px;border:1px solid #dddddd;padding:3px">Hello, you have an old version of Adobe Flash Player. To use iPaper (and lots of other stuff on the web) you need to <a href="http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash" >get the latest Flash player</a>. </div>'; }
if(quickswitch) {
/* For QuickSwitch, we avoid calling innerHTML on an element that isn't directly attached to the body. This avoids the IE issue where calling innerHTML on a block element that has in its ancestry an inline element will throw an exception */
// delete all child nodes of element if (element.hasChildNodes()) { while (element.childNodes.length >= 1) { element.removeChild(element.firstChild); }
// Event router for IE (which doesn't properly support custom events) window[ "_scribd_event_handler_" + embedName ] = function(eventType){ __this.__handleEvent(eventType) };
// // setupJsApi -- attach event listeners // var onSetupJsApi = function(e) { var e = e || {}; // In the case of IE, there will be no Event so we return an empty object
// Grab the next call on the queue, check to see if it's actionable, if not push onto a stack which will replace __callQueue var i, method, callParams, rejectedCalls = [];
for (var i=0; i<__this.__callQueue.length; i++) { callParams = __this.__callQueue[i]; if (callParams[0] == "addEventListener") { // Execute all listener calls method = callParams.shift(); __this[method].apply( __this, callParams ); } else { rejectedCalls.push( callParams ); // Send back to __callQueue } } __this.__callQueue = rejectedCalls; // end callQueue } }
var oniPaperReady = function(e) { var e = e || {}; // In the case of IE, there will be no Event so we return an empty object
if (target.getAttribute('name') == embedName) {
if (__this.onReady){ __this.onReady(); }
// Grab the next call on the queue, check to see if it's actionable, if not push onto a stack which will replace __callQueue (rejectedCalls) var i, method, callParams, rejectedCalls = []; for (i=0; i<__this.__callQueue.length; i++) { callParams = __this.__callQueue.pop(); if (callParams[0] != "addEventListener") { // Execute all non-listener calls method = callParams.shift(); if (typeof method != "function") alert(typeof method) __this[ method ].apply( __this, callParams ); } else { rejectedCalls.push( callParams ); // Send back to __callQueue } } __this.__callQueue = rejectedCalls;
// TODO: implement this properly - redispatch initial mouse over event in case browser missed it (firefox, webkit)
// { // var evt = target.ownerDocument.createEvent('MouseEvents'); // evt.initMouseEvent('mouseover', true, true, // // target.ownerDocument.defaultView, 1, 0, 0, 0, 0, false, false, false, false, 0, null);
// target.dispatchEvent(evt); // } } }
if (window.addEventListener){ window.addEventListener('iPaperReady', oniPaperReady, true); window.addEventListener('setupJsApi', onSetupJsApi, true) } else { // No DOM 2 Support this.__addRoutedListener('iPaperReady', oniPaperReady); this.__addRoutedListener('setupJsApi', onSetupJsApi); }
// initial mouse over notification (for firefox and chrome) // this.initialMouseOver = false; // // if (window.addEventListener){ // element.addEventListener('mouseover', function() { __this.initialMouseOver = true; }, false);
/* -----------------------AC_RunActiveContent
Modified to return the embed string, rather than use document.write - modified functions prefixed with 'Mod_' Implied consent for use: http://www.adobe.com/devnet/activecontent/articles/devletter.html
-------------------------- */
// v1.7 // Flash Player Version Detection // Detect Client Browser type // Copyright 2005-2007 Adobe Systems Incorporated. All rights reserved. var isIE = (navigator.appVersion.indexOf("MSIE") != -1) ? true : false; var isWin = (navigator.appVersion.toLowerCase().indexOf("win") != -1) ? true : false;
try { // version will be set for 7.X or greater players axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7"); version = axo.GetVariable("$version"); } catch (e) { }
if (!version) { try { // version will be set for 6.X players only axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
} catch (e) { } }
if (!version) { try { // version will be set for 4.X or 5.X player axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3"); version = axo.GetVariable("$version"); } catch (e) { } }
if (!version) { try { // version will be set for 3.X player axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3"); version = "WIN 3,0,18,0"; } catch (e) { } }
if (!version) { try { // version will be set for 2.X player axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash"); version = "WIN 2,0,0,11"; } catch (e) { version = -1; } }
return version; };
// JavaScript helper required to detect Flash Player PlugIn version information this.GetSwfVer = function(){ // NS/Opera version >= 3 check for Flash plugin in plugin array var flashVer = -1;
if (navigator.plugins != null && navigator.plugins.length > 0) { if (navigator.plugins["Shockwave Flash 2.0"] || navigator.plugins["Shockwave Flash"]) { var swVer2 = navigator.plugins["Shockwave Flash 2.0"] ? " 2.0" : ""; var flashDescription = navigator.plugins["Shockwave Flash" + swVer2].description; var descArray = flashDescription.split(" "); var tempArrayMajor = descArray[2].split("."); var versionMajor = tempArrayMajor[0]; var versionMinor = tempArrayMajor[1]; var versionRevision = descArray[3]; if (versionRevision == "") { versionRevision = descArray[4]; } if (versionRevision[0] == "d") { versionRevision = versionRevision.substring(1); } else if (versionRevision[0] == "r") { versionRevision = versionRevision.substring(1); if (versionRevision.indexOf("d") > 0) { versionRevision = versionRevision.substring(0, versionRevision.indexOf("d")); } }
var flashVer = versionMajor + "." + versionMinor + "." + versionRevision; } } // MSN/WebTV 2.6 supports Flash 4 else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.6") != -1) flashVer = 4; // WebTV 2.5 supports Flash 3 else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.5") != -1) flashVer = 3; // older WebTV supports Flash 2 else if (navigator.userAgent.toLowerCase().indexOf("webtv") != -1) flashVer = 2; else if ( isIE && isWin && !isOpera ) { flashVer = this.ControlVersion(); } return flashVer; };
// When called with reqMajorVer, reqMinorVer, reqRevision returns true if that version or greater is available this.DetectFlashVer = function(reqMajorVer, reqMinorVer, reqRevision) { versionStr = this.GetSwfVer(); if (versionStr == -1 ) { return false; } else if (versionStr != 0) { if(isIE && isWin && !isOpera) { // Given "WIN 2,0,0,11" tempArray = versionStr.split(" "); // ["WIN", "2,0,0,11"]
= tempArray[1];
// "2,0,0,11"
= versionStr.split(".");
= versionArray[0]; = versionArray[1];
// is the major.revision >= requested major.revision AND the minor version >= requested minor if (versionMajor > parseFloat(reqMajorVer)) { return true; } else if (versionMajor == parseFloat(reqMajorVer)) { if (versionMinor > parseFloat(reqMinorVer)) return true; else if (versionMinor == parseFloat(reqMinorVer)) { if (versionRevision >= parseFloat(reqRevision)) return true; } } return false; } };
this.Mod_AC_Generateobj = function(objAttrs, params, embedAttrs) { var str = ''; if (isIE && isWin && !isOpera) { str += '<object '; for (var i in objAttrs) { str += i + '="' + objAttrs[i] + '" '; } str += '>'; for (var i in params) { str += '<param name="' + i + '" value="' + params[i] + '" /> '; } str += '</object>'; } else
{ str += '<embed '; for (var i in embedAttrs) { str += i + '="' + embedAttrs[i] + '" '; } str += '> </embed>'; }
return str; };
this.Mod_AC_FL_RunContent = function(){ var ret = this.Mod_AC_GetArgs( arguments, ".swf", "movie", "clsid:d27cdb6e-ae6d-11cf-96b8444553540000", "application/x-shockwave-flash" );
this.Mod_AC_SW_RunContent = function(){ var ret = this.Mod_AC_GetArgs ( arguments, ".dcr", "src", "clsid:166B1BCA-3F9C-11CF-8075-444553540000" , null ); return this.Mod_AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs);
};
this.Mod_AC_GetArgs = function(args, ext, srcParamName, classid, mimeType){ var ret = new Object(); ret.embedAttrs = new Object(); ret.params = new Object(); ret.objAttrs = new Object(); for (var i=0; i < args.length; i=i+2){ var currArg = args[i].toLowerCase();
switch (currArg){ case "classid": break; case "pluginspage": ret.embedAttrs[args[i]] = args[i+1]; break; case "src": case "movie": args[i+1] = this.AC_AddExtension(args[i+1], ext); ret.embedAttrs["src"] = args[i+1]; ret.params[srcParamName] = args[i+1]; break; case "onafterupdate": case "onbeforeupdate": case "onblur":
case "oncellchange": case "onclick": case "ondblclick": case "ondrag": case "ondragend": case "ondragenter": case "ondragleave": case "ondragover": case "ondrop": case "onfinish": case "onfocus": case "onhelp": case "onmousedown": case "onmouseup": case "onmouseover": case "onmousemove": case "onmouseout": case "onkeypress": case "onkeydown": case "onkeyup": case "onload": case "onlosecapture": case "onpropertychange": case "onreadystatechange": case "onrowsdelete":
case "onrowenter": case "onrowexit": case "onrowsinserted": case "onstart": case "onscroll": case "onbeforeeditfocus": case "onactivate": case "onbeforedeactivate": case "ondeactivate": case "type": case "codebase": case "id": ret.objAttrs[args[i]] = args[i+1]; break; case "width": case "height": case "align": case "vspace": case "hspace": case "class": case "title": case "accesskey": case "name": case "tabindex": ret.embedAttrs[args[i]] = ret.objAttrs[args[i]] = args[i+1];
break; default: ret.embedAttrs[args[i]] = ret.params[args[i]] = args[i+1]; } } ret.objAttrs["classid"] = classid; if (mimeType) ret.embedAttrs["type"] = mimeType; return ret; }
// call callback function if defined // this is used so we make sure view.js is loaded before calling // other code that depends on it if(typeof scribd_view_callback != "undefined") { scribd_view_callback(); } }