This File Appears to Be Written So
-
Upload
ankur-gupta -
Category
Documents
-
view
49 -
download
0
Transcript of This File Appears to Be Written So
//this file appears to be written so that does not require prototype, fyi - tom
if(typeof scribd == "undefined") {
var scribd = new Object();
/* ------------------------
Scribd Document
-------------------------- */
scribd.Document = function() {
//Private vars
this.__params = [ ]; // document attributes
this.__callQueue = [ ]; // stores premature method calls for later replay, technically a stack (FILO)
this.__listenerLookup = { }; // lookup[ eventType:String ] -> [ callback1:Function, callback2:Function ... ]
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.getDocFromUrlForExtension = function(url, extension_id) {
scribd_doc = new scribd.Document();
scribd_doc.url = url;
scribd_doc.extension_id = extension_id;
scribd_doc.addParam("should_redirect", true);
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
----------------- */
__handleEvent: function( eventType ){
var listeners = this.__listenerLookup[eventType] || [];
for (var i=0; i<listeners.length; i++)
{
listeners[i]();
}
},
__addRoutedListener: function( eventType, callback ){
if ( this.__listenerExists(eventType, callback) )
return;
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;
},
/* ---------------
Public Methods
---------------- */
addEventListener: function( eventType, callback, optBubble ){
if (this.api){
if (window.addEventListener){
this.api.parentNode.addEventListener( eventType, callback, false );
} else {
this.__addRoutedListener( eventType, callback );
}
} else {
this.__callQueue.push(["addEventListener", eventType, callback, false]);
}
},
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]);
}
},
getElement : function () {
return document.getElementsByName( this.__embedName )[0]
},
addParam : function(name, value) {
this.__params[name] = value;
},
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;
},
write : function(elementId) {
var element = document.getElementById(elementId);
quickswitch = (this.__params["quickswitch"] == true);
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"]){
view_mode = this.__params['mode'];
flashVars += '&viewMode=' + escape(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;
page_height -= 25; // some breathing room
// Bound the height
if (auto_height < 200) {
auto_height = 200;
}
if (auto_height > page_height) {
auto_height = page_height;
}
var embedHeight = auto_height + "px";
} else {
var embedHeight = "100%";
}
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";
}
// Params
if (this.__params["swf_name"]){
srcString = this.__params["swf_name"];
}
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"];
}
// Document Attributes
if (this.document_id){
flashVars += '&document_id=' + this.document_id;
}
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 srcPath = "http://d1.scribdassets.com/";
var protocol = "http://";
if (this.__params["use_ssl"] == true) {
srcPath = "https://s3.amazonaws.com/documents.scribd.com/";
flashVars += "&use_ssl=true";
protocol = 'https://';
}
if (this.__params["src_path"]) {
srcPath = this.__params["src_path"];
}
if (this.__params["hide_sample_banner"]){
flashVars += '&hide_sample_banner=' + this.__params["hide_sample_banner"];
}
if (this.__params["disable_resume_reading"] == true){
flashVars += '&disable_resume_reading=true';
}
if (this.__params["hide_full_screen_button"] == true){
flashVars += '&hide_full_screen_button=true';
}
if (this.__params["hide_disabled_buttons"] == true){
flashVars += '&hide_disabled_buttons=true';
}
if (this.__params["full_screen_type"]){
flashVars += '&full_screen_type=' + this.__params["full_screen_type"];
}
if (this.__params["custom_logo_image_url"]) {
flashVars += '&custom_logo_image_url=' + escape(this.__params["custom_logo_image_url"]);
}
if (this.__params["custom_logo_click_url"]) {
flashVars += '&custom_logo_click_url=' + escape(this.__params["custom_logo_click_url"]);
}
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 */
// set container innerHTML, which is a direct child of body
container.innerHTML = embedString;
// delete all child nodes of element
if (element.hasChildNodes()) {
while (element.childNodes.length >= 1) {
element.removeChild(element.firstChild);
}
}
element.appendChild(container);
}
else
{
element.innerHTML = embedString;
}
var __this = this;
// 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
var target = e.srcElement || document.getElementsByName(embedName)[0];
if (target.getAttribute('name') == embedName)
{
__this.api = target;
// 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
}
}
//
// iPaperReady -- pump call queue
//
var oniPaperReady = function(e)
{
var e = e || {}; // In the case of IE, there will be no Event so we return an empty object
var target = e.srcElement || document.getElementsByName(embedName)[0];
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)
// if (__this.initialMouseOver && target.dispatchEvent)
// {
// 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);
// element.addEventListener('mouseout', function() { __this.initialMouseOver = false; }, false);
// }
}
}
var Scribd_AC_RunActiveContent = new function()
{
/* ------------------------
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;
var isOpera = (navigator.userAgent.indexOf("Opera") != -1) ? true : false;
this.ControlVersion = function()
{
var version;
var axo;
var e;
// NOTE : new ActiveXObject(strFoo) throws an exception if strFoo isn't in the registry
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");
// installed player is some revision of 6.0
// GetVariable("$version") crashes for versions 6.0.22 through 6.0.29,
// so we have to be careful.
// default to the first public version
version = "WIN 6,0,21,0";
// throws if AllowScripAccess does not exist (introduced in 6.0r47)
axo.AllowScriptAccess = "always";
// safe to call for 6.0r47 or greater
version = axo.GetVariable("$version");
} 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"]
tempString = tempArray[1]; // "2,0,0,11"
versionArray = tempString.split(","); // ['2', '0', '0', '11']
} else {
versionArray = versionStr.split(".");
}
var versionMajor = versionArray[0];
var versionMinor = versionArray[1];
var versionRevision = versionArray[2];
// 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.AC_AddExtension = function(src, ext)
{
if (src.indexOf('?') != -1)
return src.replace(/\?/, ext+'?');
else
return src + ext;
};
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-96b8-444553540000", "application/x-shockwave-flash" );
return this.Mod_AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs);
}
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();
}
}
}
/* ------------------------
(c) Scribd 2008
------------------------- */