Clean
| @ -1,56 +0,0 @@ | ||||
| /* | ||||
| Product Name: dhtmlxVault  | ||||
| Version: 2.4  | ||||
| Edition: Standard  | ||||
| License: content of this file is covered by GPL. Usage outside GPL terms is prohibited. To obtain Commercial or Enterprise license contact sales@dhtmlx.com | ||||
| Copyright UAB Dinamenta http://www.dhtmlx.com | ||||
| */ | ||||
|  | ||||
| /* deprecated */ | ||||
| dhtmlXVaultObject.prototype.setServerHandlers = function(uploadHandler) { | ||||
| 	// defines server-side handlers for vault | ||||
| 	// moved to init, only for html4/tml5 | ||||
| 	this.conf.upload_url = uploadHandler; | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.setImagePath = function(imagePath) { | ||||
| 	// set relative path to the images folder | ||||
| 	// no longer needed | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.create = function(container) { | ||||
| 	// creates vault html control on page | ||||
| 	// no longer needed, created automaticaly from constructor | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.onAddFile = function(handler) { | ||||
| 	// called when user has selected a file for uploading | ||||
| 	this.attachEvent("onBeforeFileAdd", function(name,size){ | ||||
| 		return handler.apply(this,[name]); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.onFileUploaded = function(handler) { | ||||
| 	// called after every file is uploaded | ||||
| 	this.attachEvent("onUploadFile", function(f){ | ||||
| 		handler.apply(this,[f]); | ||||
| 	}); | ||||
| 	this.attachEvent("onUploadFail", function(f){ | ||||
| 		handler.apply(this,[f]); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.onUploadComplete = function(handler) { | ||||
| 	// called after all files are uploaded | ||||
| 	this.attachEvent("onUploadComplete", function(fs){ | ||||
| 		handler.apply(this, fs); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.setFormField = function(name, value) { | ||||
| 	// adds custom fields to the form | ||||
| 	for (var a in {url:1, swf_url:1, sl_url:1}) { | ||||
| 		this.conf[a] += (String(this.conf[a]).indexOf("?")<0?"?":"&")+name+"="+encodeURIComponent(value); | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| @ -1,223 +0,0 @@ | ||||
| /* | ||||
| Product Name: dhtmlxVault  | ||||
| Version: 2.4  | ||||
| Edition: Standard  | ||||
| License: content of this file is covered by GPL. Usage outside GPL terms is prohibited. To obtain Commercial or Enterprise license contact sales@dhtmlx.com | ||||
| Copyright UAB Dinamenta http://www.dhtmlx.com | ||||
| */ | ||||
|  | ||||
| dhtmlXVaultObject.prototype.load = function(url, callback) { // load list of early uploaded files from server | ||||
| 	 | ||||
| 	if (this.conf.dataload_inited != true) { | ||||
| 		 | ||||
| 		this.conf.dataload_inited = true; | ||||
| 		 | ||||
| 		// check if not set - enable by the default | ||||
| 		if (typeof(this.conf.dataload_progress) == "undefined") this.conf.dataload_progress = true; | ||||
| 		 | ||||
| 		// progress events | ||||
| 		this.attachEvent("onXLS", this._progressOn); | ||||
| 		this.attachEvent("onXLE", this._progressOff); | ||||
| 		 | ||||
| 		// use common data loading functionality, | ||||
| 		// it will override current function after first call | ||||
| 		window.dhx4._enableDataLoading(this, "_initObj", "_xmlToObj", "files", {data:true}); | ||||
| 		 | ||||
| 		this.load.apply(this, arguments); | ||||
| 	} | ||||
| 	 | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype.addFileRecord = function(file, status) { // add custom file record to list | ||||
| 	 | ||||
| 	if (status == null || {added: true, uploaded: true}[status] != true) return; | ||||
| 	 | ||||
| 	var id = window.dhx4.newId(); | ||||
| 	if (typeof(file.name) == "undefined" || file.name == null) file.name = "New File Record"; | ||||
| 	if (typeof(file.size) == "undefined" || file.size == null) file.size = false; // not set | ||||
| 	 | ||||
| 	this.file_data[id] = {file:{}}; | ||||
| 	 | ||||
| 	this._addFileToList(id, file.name, file.size, status, 0); | ||||
| 	 | ||||
| 	if (status == "uploaded") { | ||||
| 		if (typeof(file.serverName) == "undefined" && file.serverName == null) file.serverName = file.name; | ||||
| 		this.conf.uploaded_files[id] = { realName: file.name, serverName: file.serverName }; | ||||
| 		if (this.conf.download_url.length > 0) this.list.updateFileNameSize(id, {download: true}); | ||||
| 	}; | ||||
| 	 | ||||
| 	this.file_data[id] = { | ||||
| 		name: file.name, | ||||
| 		size: file.size, | ||||
| 		state: status, // "added", "uploaded" | ||||
| 		file: {}, | ||||
| 		custom: true,  // required for custom record | ||||
| 		fileData: file // will go to server | ||||
| 	}; | ||||
| 	 | ||||
| 	this.list.updateFileState(id, {state: status, str_done: this.strings.done}); | ||||
| 	 | ||||
| 	if (this.conf.auto_start && !this.conf.uploading) this._uploadStart(true); | ||||
| }; | ||||
|  | ||||
| // uploading | ||||
| dhtmlXVaultObject.prototype._cfOnUpload = function() { | ||||
| 	 | ||||
| 	if (this.cf_loader_id == null) return; | ||||
| 	var id = this.cf_loader_id; | ||||
| 	this.cf_loader_id = null; | ||||
| 	 | ||||
| 	dhx4.temp = null; | ||||
| 	try {eval("dhx4.temp="+this.cf_loader.responseText);} catch(e){}; | ||||
| 	var r = dhx4.temp; | ||||
| 	dhx4.temp = null; | ||||
| 	 | ||||
| 	try { | ||||
| 		this.cf_loader.onreadystatechange = null; | ||||
| 		this.cf_loader = null; | ||||
| 	} catch(e){}; | ||||
| 	 | ||||
| 	try { | ||||
| 		delete this.cf_loader.onreadystatechange; | ||||
| 		delete this.cf_loader; | ||||
| 	} catch(e){}; | ||||
| 	 | ||||
| 	if (r != null && typeof(r) == "object" && typeof(r.state) != "undefined" && r.state == true) { | ||||
| 		if (this.file_data[id].custom == true && typeof(r.size) != "undefined") this._cfUpdateSize(id, r.size); | ||||
| 		this._onUploadSuccess(id, r.name, undefined, r.extra); | ||||
| 	} else { | ||||
| 		this._onUploadFail(id, (r!=null&&r.extra!=null?r.extra:null)); | ||||
| 	} | ||||
| 	 | ||||
| 	r = null; | ||||
| 	 | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype._cfUpdateSize = function(id, size) { | ||||
| 	 | ||||
| 	this.file_data[id].size = size; | ||||
| 	var nameSizeData = { | ||||
| 		name: this.file_data[id].name, | ||||
| 		size: this.file_data[id].size, | ||||
| 		readableSize: this.readableSize(this.file_data[id].size||0) | ||||
| 	}; | ||||
| 	var t = this; | ||||
| 	window.setTimeout(function(){ | ||||
| 		t.list.updateFileNameSize(id, nameSizeData); | ||||
| 		t = nameSizeData = null; | ||||
| 	},100); | ||||
| 	 | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype._cfUploadStart = function(id) { | ||||
| 	 | ||||
| 	var postData = ["mode=custom"]; | ||||
| 	for (var a in this.file_data[id].fileData) postData.push(encodeURIComponent(a)+"="+encodeURIComponent(this.file_data[id].fileData[a])); | ||||
| 	postData = postData.join("&"); | ||||
| 	 | ||||
| 	var that = this; | ||||
| 	 | ||||
| 	this.cf_loader = (window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP")); | ||||
| 	this.cf_loader.onreadystatechange = function() { | ||||
| 		if (that.cf_loader.readyState == 4) { | ||||
| 			if (that.cf_loader.status == 200) { | ||||
| 				that._cfOnUpload(); | ||||
| 			} else if (that.cf_loader.status == 404) { | ||||
| 				that._onUploadFail(that.cf_loader_id); | ||||
| 			} | ||||
| 			that = null; | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	if (window.dhx4.ajax.cache != true) postData += (postData.length>0?"&":"")+"dhxr"+new Date().getTime(); | ||||
| 	 | ||||
| 	this.cf_loader_id = id; | ||||
| 	 | ||||
| 	this.cf_loader.open("POST", this.conf.url, true); | ||||
| 	this.cf_loader.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); | ||||
| 	this.cf_loader.setRequestHeader("X-Requested-With", "XMLHttpRequest"); | ||||
| 	this.cf_loader.send(postData); | ||||
| 	 | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype._cfUploadStop = function() { | ||||
| 	var id = this.cf_loader_id; | ||||
| 	this.cf_loader_id = null; | ||||
| 	this.cf_loader.abort(); | ||||
| 	this._onUploadAbort(id); | ||||
| }; | ||||
|  | ||||
| // data loading | ||||
| dhtmlXVaultObject.prototype._initObj = function(data) { | ||||
| 	for (var q=0; q<data.length; q++) this.addFileRecord(data[q], "uploaded"); | ||||
| }; | ||||
|  | ||||
|  | ||||
| dhtmlXVaultObject.prototype._xmlToObj = function(doc) { | ||||
| 	 | ||||
| 	var f = []; | ||||
| 	 | ||||
| 	if (!this.conf.xml_attrs) this.conf.xml_attrs = {name: "name", size: "size", serverName: "serverName"}; // xml_name:json_name | ||||
| 	 | ||||
| 	var t = doc.getElementsByTagName("files")[0]; | ||||
| 	for (var q=0; q<t.childNodes.length; q++) { | ||||
| 		if (t.childNodes[q].tagName != null && String(t.childNodes[q].tagName).toLowerCase() == "file") { | ||||
| 			var i = t.childNodes[q]; | ||||
| 			var r = {}; | ||||
| 			for (var a in this.conf.xml_attrs) { | ||||
| 				if (i.getAttribute(a) != null) { | ||||
| 					r[this.conf.xml_attrs[a]] = i.getAttribute(a); | ||||
| 				} | ||||
| 			} | ||||
| 			f.push(r); | ||||
| 			i = r = null; | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	return f; | ||||
| }; | ||||
|  | ||||
| // progress | ||||
| dhtmlXVaultObject.prototype._progressOn = function() { | ||||
| 	 | ||||
| 	if (this.conf.dataload_progress == true) { | ||||
| 		 | ||||
| 		if (this.conf.progress_tm != null) window.clearTimeout(this.conf.progress_tm); | ||||
| 		 | ||||
| 		if (this.p_progress == null) { | ||||
| 		 | ||||
| 			this.p_progress = document.createElement("DIV"); | ||||
| 			this.p_progress.className = "dhx_vault_f_pr"; | ||||
| 			this.base.appendChild(this.p_progress); | ||||
| 			 | ||||
| 			// set sizes event | ||||
| 			if (typeof(this.conf.progress_event) == "undefined") this.conf.progress_event = this.attachEvent("_onSetSizes", this._progressAdjust); | ||||
| 			 | ||||
| 			this._progressAdjust(); | ||||
| 		} | ||||
| 		 | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype._progressOff = function() { | ||||
| 	var t = this; | ||||
| 	if (this.conf.progress_tm != null) window.clearTimeout(this.conf.progress_tm); | ||||
| 	this.conf.progress_tm = window.setTimeout(function(){ | ||||
| 		if (t.p_progress != null) { | ||||
| 			t.p_progress.parentNode.removeChild(t.p_progress); | ||||
| 			t.p_progress = null; | ||||
| 		}; | ||||
| 		t = null; | ||||
| 	}, 200); | ||||
| }; | ||||
|  | ||||
| dhtmlXVaultObject.prototype._progressAdjust = function() { | ||||
| 	if (this.p_progress != null) { | ||||
| 		this.p_progress.style.left = this.p_files.style.left; | ||||
| 		this.p_progress.style.top = this.p_files.style.top; | ||||
| 		this.p_progress.style.width = this.p_files.style.width; | ||||
| 		this.p_progress.style.height = this.p_files.style.height; | ||||
| 	} | ||||
| }; | ||||
|  | ||||
|  | ||||
| Before Width: | Height: | Size: 4.6 KiB | 
| Before Width: | Height: | Size: 7.1 KiB | 
| Before Width: | Height: | Size: 4.7 KiB | 
| Before Width: | Height: | Size: 2.5 KiB | 
| @ -1,2 +0,0 @@ | ||||
| These icons are licensed under a Creative Commons Attribution 3.0 License | ||||
| http://fatcow.com/ | ||||
| Before Width: | Height: | Size: 1.4 KiB | 
| Before Width: | Height: | Size: 7.1 KiB | 
| Before Width: | Height: | Size: 7.6 KiB | 
| Before Width: | Height: | Size: 2.5 KiB | 
| @ -1,2 +0,0 @@ | ||||
| These icons are licensed under a Creative Commons Attribution 3.0 License | ||||
| http://fatcow.com/ | ||||
| Before Width: | Height: | Size: 884 B | 
| Before Width: | Height: | Size: 7.1 KiB | 
| Before Width: | Height: | Size: 8.8 KiB | 
| Before Width: | Height: | Size: 2.5 KiB | 
| @ -1,2 +0,0 @@ | ||||
| These icons are licensed under a Creative Commons Attribution 3.0 License | ||||
| http://fatcow.com/ | ||||
| Before Width: | Height: | Size: 745 B | 
| Before Width: | Height: | Size: 7.1 KiB | 
| Before Width: | Height: | Size: 8.8 KiB | 
| Before Width: | Height: | Size: 3.8 KiB | 
| @ -1,2 +0,0 @@ | ||||
| These icons are licensed under a Creative Commons Attribution 3.0 License | ||||
| http://fatcow.com/ | ||||
| @ -1,413 +0,0 @@ | ||||
| /* | ||||
| Product Name: dhtmlxVault  | ||||
| Version: 2.4  | ||||
| Edition: Standard  | ||||
| License: content of this file is covered by GPL. Usage outside GPL terms is prohibited. To obtain Commercial or Enterprise license contact sales@dhtmlx.com | ||||
| Copyright UAB Dinamenta http://www.dhtmlx.com | ||||
| */ | ||||
|  | ||||
| .dhx_vault_bootstrap { | ||||
| 	position: relative; | ||||
| 	overflow: hidden; | ||||
| 	border: 1px solid #cbc4bb; | ||||
| 	border-radius: 2px; | ||||
| 	background-color: #e0dad2; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	left: 0px; | ||||
| 	width: 100%; | ||||
| 	font-size: 13px; | ||||
| 	height: 41px; | ||||
| 	font-family: Helvetica, Verdana; | ||||
| 	color: white; | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| 	-moz-user-select: none; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_browse, | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_upload, | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_cancel, | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_clear { | ||||
| 	position: relative; | ||||
| 	float: left; | ||||
| 	display: inline; | ||||
| 	margin: 8px 1px 0px 6px; | ||||
| 	padding: 0px 4px; | ||||
| 	height: 26px; | ||||
| 	line-height: 26px; | ||||
| 	border: 0px solid white; | ||||
| 	cursor: pointer !important; | ||||
| 	overflow: hidden; | ||||
| 	-moz-user-select: none; | ||||
| 	border-radius: 4px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_browse { | ||||
| 	background-color: #5fc05f; | ||||
| 	background: linear-gradient(#5fc05f,#53a44f); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#5fc05f,endColorStr=#53a44f); | ||||
| 	border: 1px solid #4c9649; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_browse.dhx_vault_button_browse_hover { | ||||
| 	background-color: #52b652; | ||||
| 	background: linear-gradient(#52b652,#489846); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#5fc05f,endColorStr=#53a44f); | ||||
| 	border: 1px solid #4c9649; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_browse.dhx_vault_button_browse_pressed { | ||||
| 	background-color: #489845; | ||||
| 	border: 1px solid #4c9649; | ||||
| 	box-shadow: 0 2px 6px rgba(0,0,0,0.25) inset; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_upload { | ||||
| 	background-color: #4d97cb; | ||||
| 	background: linear-gradient(#4d97cb,#4882b2); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#5fc05f,endColorStr=#53a44f); | ||||
| 	border: 1px solid #3d7aa3; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_upload.dhx_vault_button_upload_hover { | ||||
| 	background-color: #4288c3; | ||||
| 	background: linear-gradient(#4288c3,#3d6fa7); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#4288c3,endColorStr=#3d6fa7); | ||||
| 	border: 1px solid #3d7aa3; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_upload.dhx_vault_button_upload_pressed { | ||||
| 	background-color: #3d6fa7; | ||||
| 	border: 1px solid #3d7aa3; | ||||
| 	box-shadow: 0 2px 6px rgba(0,0,0,0.25) inset; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_cancel { | ||||
| 	background-color: #eb5f61; | ||||
| 	background: linear-gradient(#eb5f61,#d35859); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#eb5f61,endColorStr=#d35859); | ||||
| 	border: 1px solid #bd545a; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_cancel.dhx_vault_button_cancel_hover { | ||||
| 	background-color: #e85153; | ||||
| 	background: linear-gradient(#e85153,#cc4b4c); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#e85153,endColorStr=#cc4b4c); | ||||
| 	border: 1px solid #bd545a; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_cancel.dhx_vault_button_cancel_pressed { | ||||
| 	background-color: #cc4b4c; | ||||
| 	border: 1px solid #bd545a; | ||||
| 	box-shadow: 0 2px 6px rgba(0,0,0,0.25) inset; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_clear { | ||||
| 	background-color: #f9b147; | ||||
| 	background: linear-gradient(#f9b147,#f69706); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#f9b147,endColorStr=#f69706); | ||||
| 	border: 1px solid #d48d2c; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_clear.dhx_vault_button_clear_hover { | ||||
| 	background-color: #f8a53c; | ||||
| 	background: linear-gradient(#f8a53c,#f58805); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#f8a53c,endColorStr=#f58805); | ||||
| 	border: 1px solid #d48d2c; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_button_clear.dhx_vault_button_clear_pressed { | ||||
| 	background-color: #f58805; | ||||
| 	border: 1px solid #d48d2c; | ||||
| 	box-shadow: 0 2px 6px rgba(0,0,0,0.25) inset; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhxvault_button_icon { | ||||
| 	position: relative; | ||||
| 	float: left; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 4px 2px 0px 2px; | ||||
| 	background-image: url(../imgs/dhxvault_bootstrap/dhxvault_buttons.gif); | ||||
| 	background-repeat: no-repeat; | ||||
| 	cursor: pointer !important; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhxvault_button_icon.dhx_vault_icon_browse { | ||||
| 	background-position: 0px -728px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhxvault_button_icon.dhx_vault_icon_upload { | ||||
| 	background-position: 0px -744px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhxvault_button_icon.dhx_vault_icon_cancel { | ||||
| 	background-position: 0px -760px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhxvault_button_icon.dhx_vault_icon_clear { | ||||
| 	background-position: 0px -776px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhxvault_button_text { | ||||
| 	float: left; | ||||
| 	height: 18px; | ||||
| 	line-height: 17px; | ||||
| 	margin: 4px 4px 3px 4px; | ||||
| 	cursor: pointer !important; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls .dhx_vault_input { | ||||
| 	position: absolute; | ||||
| 	left: -1000px; | ||||
| 	top: 0px; | ||||
| 	visibility: hidden; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	position: absolute; | ||||
| 	width: 100%; | ||||
| 	height: 28px; | ||||
| 	right: 0px; | ||||
| 	top: 0px; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	right: 0px; | ||||
| 	cursor: pointer; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form .dhx_vault_file_input { | ||||
| 	opacity: 0; | ||||
| 	filter: alpha(opacity=0); | ||||
| 	cursor: pointer; | ||||
| 	outline: none; | ||||
| 	height: 28px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files, | ||||
| .dhx_vault_bootstrap div.dhx_vault_f_pr { | ||||
| 	position: absolute; | ||||
| 	overflow: auto; | ||||
| 	background-color: white; | ||||
| 	border: 1px solid #cbc4bb; | ||||
| 	font-size: 14px; | ||||
| 	font-family: Helvetica, Verdana; | ||||
| 	color: black; | ||||
| 	z-index: 0; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_f_pr { | ||||
| 	background-image: url("../imgs/dhxvault_bootstrap/dhxvault_progress.gif"); | ||||
| 	background-position: center center; | ||||
| 	background-repeat: no-repeat; | ||||
| 	opacity: 0.5; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file { | ||||
| 	position: relative; | ||||
| 	width: auto; | ||||
| 	height: 53px; | ||||
| 	overflow: hidden; | ||||
| 	border-bottom: 1px solid #e9e5e0; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_added, | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploading { | ||||
| 	color: #666666; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploaded { | ||||
| 	color: #3c3c3c; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_fail { | ||||
| 	color: #e3333b; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_size_exceeded div.dhx_vault_file_param.dhx_vault_file_progress { | ||||
| 	color: #e3333b; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param { | ||||
| 	position: relative; | ||||
| 	margin: 3px 45px 0 50px; | ||||
| 	font-family: Helvetica, Verdana; | ||||
| 	font-size: 14px; | ||||
| 	color: inherit; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name { | ||||
| 	margin-top: 10px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text { | ||||
| 	position: relative; | ||||
| 	width: 100%; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| 	text-overflow: ellipsis; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a { | ||||
| 	font-family: Helvetica, Verdana; | ||||
| 	font-size: 14px; | ||||
| 	color: #3c3c3c; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a:hover { | ||||
| 	color: #6f6f6f; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	position: absolute; | ||||
| 	top: 20px; | ||||
| 	right: 15px; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 0px; | ||||
| 	background-image: url(../imgs/dhxvault_bootstrap/dhxvault_buttons.gif); | ||||
| 	background-position: 0px -792px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	cursor: pointer; | ||||
| 	-moz-user-select: none; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon { | ||||
| 	position: absolute; | ||||
| 	left: 10px; | ||||
| 	top: 11px; | ||||
| 	width: 32px; | ||||
| 	height: 32px; | ||||
| 	cursor: default; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon div.dhx_vault_all_icons { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 416px; | ||||
| 	height: 32px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	background-image: url(../imgs/dhxvault_bootstrap/dhxvault_icons.gif); | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_def div.dhx_vault_all_icons { | ||||
| 	left: 0px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_arch div.dhx_vault_all_icons { | ||||
| 	left: -32px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_audio div.dhx_vault_all_icons { | ||||
| 	left: -64px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_dmg div.dhx_vault_all_icons { | ||||
| 	left: -96px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_doc div.dhx_vault_all_icons { | ||||
| 	left: -128px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_exe div.dhx_vault_all_icons { | ||||
| 	left: -160px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_html div.dhx_vault_all_icons { | ||||
| 	left: -192px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_image div.dhx_vault_all_icons { | ||||
| 	left: -224px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_pdf div.dhx_vault_all_icons { | ||||
| 	left: -256px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_psd div.dhx_vault_all_icons { | ||||
| 	left: -288px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_text div.dhx_vault_all_icons { | ||||
| 	left: -320px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_video div.dhx_vault_all_icons { | ||||
| 	left: -352px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_xls div.dhx_vault_all_icons { | ||||
| 	left: -384px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress { | ||||
| 	position: relative; | ||||
| 	width: 130px; | ||||
| 	background-color: #e9e5e0; | ||||
| 	margin-top: 8px; | ||||
| 	margin-bottom: 5px; | ||||
| 	font-size: 7px; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress div.dhx_vault_progress_bg { | ||||
| 	height: 3px; | ||||
| 	background-color: #0073cc; | ||||
| 	font-size: inherit; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param span.progress_eta { | ||||
| 	position: absolute; | ||||
| 	top: 2px; | ||||
| 	left: 138px; | ||||
| 	font-size: 11px; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_uploading div.dhx_vault_progress div.dhx_vault_progress_loader { | ||||
| 	height: 6px; | ||||
| 	border: 1px solid #0073cc; | ||||
| 	background-color: white; | ||||
| 	background-image: url(../imgs/dhxvault_bootstrap/dhxvault_loader.gif); | ||||
| 	background-repeat: repeat-x; | ||||
| 	background-position: left center; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_flash_obj { | ||||
| 	position: absolute; | ||||
| 	display: inline; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_dnd_box { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100px; | ||||
| 	height: 100px; | ||||
| 	border: 2px dashed #c0c0c0; | ||||
| 	background-color: white; | ||||
| 	opacity: 0.75; | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_dnd_box_text { | ||||
| 	font-size: 16px; | ||||
| 	text-align: center; | ||||
| } | ||||
| .dhx_vault_bootstrap div.dhx_vault_files.dhx_vault_dnd_box_over { | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_bootstrap.dhx_vault_dis { | ||||
| 	background-color: #e8e8e8; | ||||
| 	border-color: #dbdbdb; | ||||
| } | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_files { | ||||
| 	border-color: #dbdbdb; | ||||
| } | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button_browse, | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button_upload, | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button_cancel, | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button_clear { | ||||
| 	cursor: default; | ||||
| 	opacity: 0.5; | ||||
| 	filter: alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file { | ||||
| 	opacity: 0.5; | ||||
| 	filter: alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_bootstrap.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	display: none; | ||||
| } | ||||
| .dhxvault_dframe { | ||||
| 	position: absolute; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 1px; | ||||
| 	height: 1px; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| div.dhxvault_skin_detect { | ||||
| 	position: absolute; | ||||
| 	display: block; | ||||
| 	visibility: hidden; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 110px; | ||||
| 	height: 10px; | ||||
| 	margin: 0px; | ||||
| 	padding: 0px; | ||||
| 	border: none; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| @ -1,366 +0,0 @@ | ||||
| /* | ||||
| Product Name: dhtmlxVault  | ||||
| Version: 2.4  | ||||
| Edition: Standard  | ||||
| License: content of this file is covered by GPL. Usage outside GPL terms is prohibited. To obtain Commercial or Enterprise license contact sales@dhtmlx.com | ||||
| Copyright UAB Dinamenta http://www.dhtmlx.com | ||||
| */ | ||||
|  | ||||
| /* skin detected, extra file: skins/dhx_skyblue.less */ | ||||
|  | ||||
| .dhx_vault_dhx_skyblue { | ||||
| 	position: relative; | ||||
| 	overflow: hidden; | ||||
| 	border: 1px solid #a4bed4; | ||||
| 	background-color: #eaf2fb; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	left: 0px; | ||||
| 	width: 100%; | ||||
| 	height: 37px; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 11px; | ||||
| 	color: black; | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button { | ||||
| 	position: relative; | ||||
| 	float: left; | ||||
| 	display: inline; | ||||
| 	margin: 5px 1px 0px 1px; | ||||
| 	height: 22px; | ||||
| 	line-height: 21px; | ||||
| 	padding: 2px 3px; | ||||
| 	border: 1px solid #a4bed4; | ||||
| 	background-color: #f7f9fc; | ||||
| 	background: linear-gradient(#f7f9fc,#eaf2fb); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#f7f9fc,endColorStr=#eaf2fb) progid:DXImageTransform.Microsoft.Alpha(opacity=100); | ||||
| 	border-radius: 2px; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button.dhx_vault_button_hover { | ||||
| 	background-color: #f3f7fd; | ||||
| 	background: linear-gradient(#f3f7fd,#e6f0fa); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#f3f7fd,endColorStr=#e6f0fa) progid:DXImageTransform.Microsoft.Alpha(opacity=100); | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button.dhx_vault_button_pressed { | ||||
| 	background-color: #d9e9f7; | ||||
| 	background: linear-gradient(#d9e9f7,#d9e8f8); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#d9e9f7,endColorStr=#d9e8f8) progid:DXImageTransform.Microsoft.Alpha(opacity=100); | ||||
| 	box-shadow: 0 0 5px rgba(127,127,127,0.15) inset; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon { | ||||
| 	float: left; | ||||
| 	position: relative; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 3px 3px 0px 3px; | ||||
| 	background-image: url("../imgs/dhxvault_skyblue/dhxvault_buttons.gif"); | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_browse { | ||||
| 	background-position: 0px 0px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_upload { | ||||
| 	background-position: 0px -16px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_cancel { | ||||
| 	background-position: 0px -32px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_clear { | ||||
| 	background-position: 0px -48px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_text { | ||||
| 	float: left; | ||||
| 	height: 18px; | ||||
| 	line-height: 17px; | ||||
| 	margin: 2px 4px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls .dhx_vault_input { | ||||
| 	position: absolute; | ||||
| 	left: -1000px; | ||||
| 	top: 0px; | ||||
| 	visibility: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	position: absolute; | ||||
| 	width: 100%; | ||||
| 	height: 23px; | ||||
| 	right: 0px; | ||||
| 	top: 0px; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	right: 0px; | ||||
| 	cursor: pointer; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form .dhx_vault_file_input { | ||||
| 	opacity: 0; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| 	cursor: pointer; | ||||
| 	outline: none; | ||||
| 	height: 23px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files, | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_f_pr { | ||||
| 	position: absolute; | ||||
| 	overflow: auto; | ||||
| 	background-color: white; | ||||
| 	border: 1px solid #a4bed4; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 11px; | ||||
| 	color: black; | ||||
| 	z-index: 0; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_f_pr { | ||||
| 	background-image: url("../imgs/dhxvault_skyblue/dhxvault_progress.gif"); | ||||
| 	background-position: center center; | ||||
| 	background-repeat: no-repeat; | ||||
| 	opacity: 0.5; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file { | ||||
| 	position: relative; | ||||
| 	width: auto; | ||||
| 	height: 45px; | ||||
| 	overflow: hidden; | ||||
| 	border-bottom: 1px solid #edf5ff; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_added, | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploading { | ||||
| 	color: #666666; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploaded { | ||||
| 	color: #30678a; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_fail { | ||||
| 	color: #e94a4a; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_size_exceeded div.dhx_vault_file_param.dhx_vault_file_progress { | ||||
| 	color: #e94a4a; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param { | ||||
| 	position: relative; | ||||
| 	margin: 3px 37px 0 50px; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 11px; | ||||
| 	color: inherit; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name { | ||||
| 	margin-top: 8px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text { | ||||
| 	position: relative; | ||||
| 	width: 100%; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| 	text-overflow: ellipsis; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a { | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 11px; | ||||
| 	color: inherit; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a:hover { | ||||
| 	color: #3d83b0; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	position: absolute; | ||||
| 	top: 15px; | ||||
| 	right: 11px; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 0px; | ||||
| 	background-image: url("../imgs/dhxvault_skyblue/dhxvault_buttons.gif"); | ||||
| 	background-position: 0px -64px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	cursor: pointer; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon { | ||||
| 	position: absolute; | ||||
| 	left: 10px; | ||||
| 	top: 7px; | ||||
| 	width: 32px; | ||||
| 	height: 32px; | ||||
| 	cursor: default; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon div.dhx_vault_all_icons { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 416px; | ||||
| 	height: 32px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	background-image: url("../imgs/dhxvault_skyblue/dhxvault_icons.gif"); | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_def div.dhx_vault_all_icons { | ||||
| 	left: 0px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_arch div.dhx_vault_all_icons { | ||||
| 	left: -32px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_audio div.dhx_vault_all_icons { | ||||
| 	left: -64px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_dmg div.dhx_vault_all_icons { | ||||
| 	left: -96px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_doc div.dhx_vault_all_icons { | ||||
| 	left: -128px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_exe div.dhx_vault_all_icons { | ||||
| 	left: -160px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_html div.dhx_vault_all_icons { | ||||
| 	left: -192px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_image div.dhx_vault_all_icons { | ||||
| 	left: -224px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_pdf div.dhx_vault_all_icons { | ||||
| 	left: -256px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_psd div.dhx_vault_all_icons { | ||||
| 	left: -288px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_text div.dhx_vault_all_icons { | ||||
| 	left: -320px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_video div.dhx_vault_all_icons { | ||||
| 	left: -352px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_xls div.dhx_vault_all_icons { | ||||
| 	left: -384px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress { | ||||
| 	position: relative; | ||||
| 	width: 110px; | ||||
| 	border: 1px solid #a4bed4; | ||||
| 	margin-top: 3px; | ||||
| 	margin-bottom: 3px; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 7px; | ||||
| 	color: black; | ||||
| 	border-radius: 2px; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress div.dhx_vault_progress_bg { | ||||
| 	height: 6px; | ||||
| 	background-color: #e5f0fd; | ||||
| 	background: linear-gradient(#e5f0fd,#d3e6fe); | ||||
| 	filter: progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr=#e5f0fd,endColorStr=#d3e6fe) progid:DXImageTransform.Microsoft.Alpha(opacity=100); | ||||
| 	background-repeat: repeat-x; | ||||
| 	font-size: inherit; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param span.progress_eta { | ||||
| 	position: absolute; | ||||
| 	top: -1px; | ||||
| 	left: 120px; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_uploading div.dhx_vault_progress div.dhx_vault_progress_loader { | ||||
| 	height: 6px; | ||||
| 	background-color: white; | ||||
| 	background-image: url("../imgs/dhxvault_skyblue/dhxvault_loader.gif"); | ||||
| 	background-repeat: repeat-x; | ||||
| 	background-position: left center; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_flash_obj { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_dnd_box { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100px; | ||||
| 	height: 100px; | ||||
| 	border: 2px dashed #c0c0c0; | ||||
| 	background-color: white; | ||||
| 	opacity: 0.75; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=75); | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_dnd_box_text { | ||||
| 	font-size: 16px; | ||||
| 	text-align: center; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue div.dhx_vault_files.dhx_vault_dnd_box_over { | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue.dhx_vault_dis { | ||||
| 	background-color: #f7f7f7; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button { | ||||
| 	cursor: default; | ||||
| 	opacity: 0.5; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_dhx_skyblue.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file { | ||||
| 	opacity: 0.5; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_dhx_skyblue.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_skyblue.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	display: none; | ||||
| } | ||||
| .dhxvault_dframe { | ||||
| 	position: absolute; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 1px; | ||||
| 	height: 1px; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| div.dhxvault_skin_detect { | ||||
| 	position: absolute; | ||||
| 	display: block; | ||||
| 	visibility: hidden; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 10px; | ||||
| 	height: 10px; | ||||
| 	margin: 0px; | ||||
| 	padding: 0px; | ||||
| 	border: none; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| @ -1,359 +0,0 @@ | ||||
| /* | ||||
| Product Name: dhtmlxVault  | ||||
| Version: 2.4  | ||||
| Edition: Standard  | ||||
| License: content of this file is covered by GPL. Usage outside GPL terms is prohibited. To obtain Commercial or Enterprise license contact sales@dhtmlx.com | ||||
| Copyright UAB Dinamenta http://www.dhtmlx.com | ||||
| */ | ||||
|  | ||||
| /* skin detected, extra file: skins/dhx_terrace.less */ | ||||
|  | ||||
| .dhx_vault_dhx_terrace { | ||||
| 	position: relative; | ||||
| 	overflow: hidden; | ||||
| 	border: 1px solid #cccccc; | ||||
| 	background-color: #f5f5f5; | ||||
| 	border-radius: 3px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	left: 0px; | ||||
| 	width: 100%; | ||||
| 	font-family: Arial, Helvetica; | ||||
| 	font-size: 13px; | ||||
| 	color: #333333; | ||||
| 	height: 45px; | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button { | ||||
| 	position: relative; | ||||
| 	float: left; | ||||
| 	display: inline; | ||||
| 	margin: 7px 0px 0px 0px; | ||||
| 	padding: 3px 5px; | ||||
| 	height: 22px; | ||||
| 	line-height: 22px; | ||||
| 	background-color: #f0f0f0; | ||||
| 	border: 1px solid #cccccc; | ||||
| 	border-radius: 3px; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button.dhx_vault_button_hover { | ||||
| 	background-color: #ebebeb; | ||||
| 	color: black; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button.dhx_vault_button_pressed { | ||||
| 	background-color: #e6e6e6; | ||||
| 	box-shadow: 0 0 5px rgba(127,127,127,0.15) inset; | ||||
| 	color: black; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon { | ||||
| 	float: left; | ||||
| 	position: relative; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 2px; | ||||
| 	background-image: url("../imgs/dhxvault_terrace/dhxvault_buttons.gif"); | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_browse { | ||||
| 	background-position: 0px 0px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_upload { | ||||
| 	background-position: 0px -16px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_cancel { | ||||
| 	background-position: 0px -32px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_clear { | ||||
| 	background-position: 0px -48px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_text { | ||||
| 	float: left; | ||||
| 	height: 18px; | ||||
| 	line-height: 17px; | ||||
| 	margin: 2px 4px; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls .dhx_vault_input { | ||||
| 	position: absolute; | ||||
| 	left: -1000px; | ||||
| 	top: 0px; | ||||
| 	visibility: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	position: absolute; | ||||
| 	width: 100%; | ||||
| 	height: 32px; | ||||
| 	right: 0px; | ||||
| 	top: 0px; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	right: 0px; | ||||
| 	cursor: pointer; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form .dhx_vault_file_input { | ||||
| 	opacity: 0; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| 	cursor: pointer; | ||||
| 	outline: none; | ||||
| 	height: 32px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files, | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_f_pr { | ||||
| 	position: absolute; | ||||
| 	overflow: auto; | ||||
| 	background-color: #ffffff; | ||||
| 	border: 1px solid #cccccc; | ||||
| 	border-radius: 3px; | ||||
| 	font-family: Arial, Helvetica; | ||||
| 	font-size: 11px; | ||||
| 	color: black; | ||||
| 	z-index: 0; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_f_pr { | ||||
| 	background-image: url("../imgs/dhxvault_terrace/dhxvault_progress.gif"); | ||||
| 	background-position: center center; | ||||
| 	background-repeat: no-repeat; | ||||
| 	opacity: 0.5; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file { | ||||
| 	position: relative; | ||||
| 	width: auto; | ||||
| 	height: 45px; | ||||
| 	overflow: hidden; | ||||
| 	border-bottom: 1px solid #cccccc; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_added, | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploading { | ||||
| 	color: #777777; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploaded { | ||||
| 	color: black; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_fail { | ||||
| 	color: #e94a4a; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_size_exceeded div.dhx_vault_file_param.dhx_vault_file_progress { | ||||
| 	color: #e94a4a; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param { | ||||
| 	position: relative; | ||||
| 	margin: 0px 37px 0 48px; | ||||
| 	font-family: Arial, Helvetica; | ||||
| 	font-size: 13px; | ||||
| 	color: inherit; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name { | ||||
| 	margin-top: 7px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text { | ||||
| 	position: relative; | ||||
| 	width: 100%; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| 	text-overflow: ellipsis; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a { | ||||
| 	font-family: Arial, Helvetica; | ||||
| 	font-size: 13px; | ||||
| 	color: inherit; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a:hover { | ||||
| 	color: #4d4d4d; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	position: absolute; | ||||
| 	top: 15px; | ||||
| 	right: 11px; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 0px; | ||||
| 	background-image: url("../imgs/dhxvault_terrace/dhxvault_buttons.gif"); | ||||
| 	background-position: 0px -64px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	cursor: pointer; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon { | ||||
| 	position: absolute; | ||||
| 	left: 8px; | ||||
| 	top: 7px; | ||||
| 	width: 32px; | ||||
| 	height: 32px; | ||||
| 	cursor: default; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon div.dhx_vault_all_icons { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 416px; | ||||
| 	height: 32px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	background-image: url("../imgs/dhxvault_terrace/dhxvault_icons.gif"); | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_def div.dhx_vault_all_icons { | ||||
| 	left: 0px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_arch div.dhx_vault_all_icons { | ||||
| 	left: -32px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_audio div.dhx_vault_all_icons { | ||||
| 	left: -64px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_dmg div.dhx_vault_all_icons { | ||||
| 	left: -96px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_doc div.dhx_vault_all_icons { | ||||
| 	left: -128px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_exe div.dhx_vault_all_icons { | ||||
| 	left: -160px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_html div.dhx_vault_all_icons { | ||||
| 	left: -192px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_image div.dhx_vault_all_icons { | ||||
| 	left: -224px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_pdf div.dhx_vault_all_icons { | ||||
| 	left: -256px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_psd div.dhx_vault_all_icons { | ||||
| 	left: -288px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_text div.dhx_vault_all_icons { | ||||
| 	left: -320px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_video div.dhx_vault_all_icons { | ||||
| 	left: -352px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_xls div.dhx_vault_all_icons { | ||||
| 	left: -384px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress { | ||||
| 	position: relative; | ||||
| 	width: 110px; | ||||
| 	border: 1px solid #cccccc; | ||||
| 	margin-top: 3px; | ||||
| 	margin-bottom: 3px; | ||||
| 	font-size: 7px; | ||||
| 	border-radius: 2px; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress div.dhx_vault_progress_bg { | ||||
| 	height: 6px; | ||||
| 	background-color: #ececec; | ||||
| 	font-size: inherit; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param span.progress_eta { | ||||
| 	position: absolute; | ||||
| 	top: -1px; | ||||
| 	left: 120px; | ||||
| 	font-size: 11px; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_uploading div.dhx_vault_progress div.dhx_vault_progress_loader { | ||||
| 	height: 6px; | ||||
| 	background-color: white; | ||||
| 	background-image: url("../imgs/dhxvault_terrace/dhxvault_loader.gif"); | ||||
| 	background-repeat: repeat-x; | ||||
| 	background-position: left center; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_flash_obj { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_dnd_box { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100px; | ||||
| 	height: 100px; | ||||
| 	border: 2px dashed #c0c0c0; | ||||
| 	border-radius: 3px; | ||||
| 	background-color: #ffffff; | ||||
| 	opacity: 0.75; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=75); | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_dnd_box_text { | ||||
| 	font-size: 16px; | ||||
| 	text-align: center; | ||||
| } | ||||
| .dhx_vault_dhx_terrace div.dhx_vault_files.dhx_vault_dnd_box_over { | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_terrace.dhx_vault_dis { | ||||
| 	background-color: #f7f7f7; | ||||
| } | ||||
| .dhx_vault_dhx_terrace.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button { | ||||
| 	cursor: default; | ||||
| 	opacity: 0.5; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_dhx_terrace.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file { | ||||
| 	opacity: 0.5; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_dhx_terrace.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_terrace.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	display: none; | ||||
| } | ||||
| .dhxvault_dframe { | ||||
| 	position: absolute; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 1px; | ||||
| 	height: 1px; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| div.dhxvault_skin_detect { | ||||
| 	position: absolute; | ||||
| 	display: block; | ||||
| 	visibility: hidden; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 30px; | ||||
| 	height: 10px; | ||||
| 	margin: 0px; | ||||
| 	padding: 0px; | ||||
| 	border: none; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| @ -1,359 +0,0 @@ | ||||
| /* | ||||
| Product Name: dhtmlxVault  | ||||
| Version: 2.4  | ||||
| Edition: Standard  | ||||
| License: content of this file is covered by GPL. Usage outside GPL terms is prohibited. To obtain Commercial or Enterprise license contact sales@dhtmlx.com | ||||
| Copyright UAB Dinamenta http://www.dhtmlx.com | ||||
| */ | ||||
|  | ||||
| /* skin detected, extra file: skins/dhx_web.less */ | ||||
|  | ||||
| .dhx_vault_dhx_web { | ||||
| 	position: relative; | ||||
| 	overflow: hidden; | ||||
| 	background-color: #3da0e3; | ||||
| 	border: 1px solid #3da0e3; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	left: 0px; | ||||
| 	width: 100%; | ||||
| 	height: 36px; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 12px; | ||||
| 	color: #ffffff; | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button { | ||||
| 	position: relative; | ||||
| 	float: left; | ||||
| 	display: inline; | ||||
| 	margin: 6px 3px 3px 3px; | ||||
| 	padding: 2px 3px 1px; | ||||
| 	height: 22px; | ||||
| 	line-height: 22px; | ||||
| 	border: 0px solid white; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button.dhx_vault_button_hover { | ||||
| 	background-color: #2a8ed2; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button.dhx_vault_button_pressed { | ||||
| 	background-color: #2589ce; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon { | ||||
| 	float: left; | ||||
| 	position: relative; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 3px 3px 0px 3px; | ||||
| 	background-image: url("../imgs/dhxvault_web/dhxvault_buttons.gif"); | ||||
| 	background-repeat: no-repeat; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_browse { | ||||
| 	background-position: 0px 0px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_upload { | ||||
| 	background-position: 0px -16px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_cancel { | ||||
| 	background-position: 0px -32px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_icon.dhx_vault_icon_clear { | ||||
| 	background-position: 0px -48px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_button div.dhxvault_button_text { | ||||
| 	float: left; | ||||
| 	height: 18px; | ||||
| 	line-height: 17px; | ||||
| 	margin: 2px 4px; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls .dhx_vault_input { | ||||
| 	position: absolute; | ||||
| 	left: -1000px; | ||||
| 	top: 0px; | ||||
| 	visibility: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	position: absolute; | ||||
| 	width: 100%; | ||||
| 	height: 30px; | ||||
| 	right: 0px; | ||||
| 	top: 0px; | ||||
| 	cursor: pointer; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form { | ||||
| 	position: absolute; | ||||
| 	top: 0px; | ||||
| 	right: 0px; | ||||
| 	cursor: pointer; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_controls div.dhx_vault_file_form_cont form.dhx_vault_file_form .dhx_vault_file_input { | ||||
| 	opacity: 0; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| 	cursor: pointer; | ||||
| 	outline: none; | ||||
| 	height: 30px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files, | ||||
| .dhx_vault_dhx_web div.dhx_vault_f_pr { | ||||
| 	position: absolute; | ||||
| 	overflow: auto; | ||||
| 	background-color: #ffffff; | ||||
| 	border: 1px solid #ffffff; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 12px; | ||||
| 	color: #000000; | ||||
| 	z-index: 0; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_f_pr { | ||||
| 	background-image: url("../imgs/dhxvault_web/dhxvault_progress.gif"); | ||||
| 	background-position: center center; | ||||
| 	background-repeat: no-repeat; | ||||
| 	opacity: 0.5; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file { | ||||
| 	position: relative; | ||||
| 	width: auto; | ||||
| 	height: 45px; | ||||
| 	overflow: hidden; | ||||
| 	border-bottom: 1px solid #ececec; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_added, | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploading { | ||||
| 	color: #777777; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_uploaded { | ||||
| 	color: black; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_fail { | ||||
| 	color: #e94a4a; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file.dhx_vault_file_size_exceeded div.dhx_vault_file_param.dhx_vault_file_progress { | ||||
| 	color: #e94a4a; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param { | ||||
| 	position: relative; | ||||
| 	margin: 0px 37px 0 48px; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 12px; | ||||
| 	color: inherit; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name { | ||||
| 	margin-top: 7px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text { | ||||
| 	position: relative; | ||||
| 	width: 100%; | ||||
| 	overflow: hidden; | ||||
| 	white-space: nowrap; | ||||
| 	text-overflow: ellipsis; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a { | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 12px; | ||||
| 	color: inherit; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_name div.dhx_vault_file_name_text a:hover { | ||||
| 	color: #4d4d4d; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	position: absolute; | ||||
| 	top: 15px; | ||||
| 	right: 11px; | ||||
| 	width: 16px; | ||||
| 	height: 16px; | ||||
| 	margin: 0px; | ||||
| 	background-image: url("../imgs/dhxvault_web/dhxvault_buttons.gif"); | ||||
| 	background-position: 0px -64px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	cursor: pointer; | ||||
| 	-webkit-user-select: none; | ||||
| 	-khtml-user-select: none; | ||||
| 	-moz-user-select: none; | ||||
| 	-ms-user-select: none; | ||||
| 	-o-user-select: none; | ||||
| 	user-select: none; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon { | ||||
| 	position: absolute; | ||||
| 	left: 8px; | ||||
| 	top: 7px; | ||||
| 	width: 32px; | ||||
| 	height: 32px; | ||||
| 	cursor: default; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon div.dhx_vault_all_icons { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 416px; | ||||
| 	height: 32px; | ||||
| 	background-repeat: no-repeat; | ||||
| 	background-image: url("../imgs/dhxvault_web/dhxvault_icons.gif"); | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_def div.dhx_vault_all_icons { | ||||
| 	left: 0px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_arch div.dhx_vault_all_icons { | ||||
| 	left: -32px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_audio div.dhx_vault_all_icons { | ||||
| 	left: -64px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_dmg div.dhx_vault_all_icons { | ||||
| 	left: -96px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_doc div.dhx_vault_all_icons { | ||||
| 	left: -128px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_exe div.dhx_vault_all_icons { | ||||
| 	left: -160px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_html div.dhx_vault_all_icons { | ||||
| 	left: -192px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_image div.dhx_vault_all_icons { | ||||
| 	left: -224px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_pdf div.dhx_vault_all_icons { | ||||
| 	left: -256px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_psd div.dhx_vault_all_icons { | ||||
| 	left: -288px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_text div.dhx_vault_all_icons { | ||||
| 	left: -320px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_video div.dhx_vault_all_icons { | ||||
| 	left: -352px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_icon.dhx_vault_icon_xls div.dhx_vault_all_icons { | ||||
| 	left: -384px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress { | ||||
| 	position: relative; | ||||
| 	width: 110px; | ||||
| 	border: 1px solid #cecece; | ||||
| 	margin-top: 3px; | ||||
| 	margin-bottom: 3px; | ||||
| 	font-family: Tahoma, Helvetica; | ||||
| 	font-size: 7px; | ||||
| 	color: #000000; | ||||
| 	border-radius: 2px; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param div.dhx_vault_progress div.dhx_vault_progress_bg { | ||||
| 	height: 6px; | ||||
| 	background-color: #ececec; | ||||
| 	font-size: inherit; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param span.progress_eta { | ||||
| 	position: absolute; | ||||
| 	top: -1px; | ||||
| 	left: 120px; | ||||
| 	font-size: 12px; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_uploading div.dhx_vault_progress div.dhx_vault_progress_loader { | ||||
| 	height: 6px; | ||||
| 	background-color: #ffffff; | ||||
| 	background-image: url("../imgs/dhxvault_web/dhxvault_loader.gif"); | ||||
| 	background-repeat: repeat-x; | ||||
| 	background-position: left center; | ||||
| 	overflow: hidden; | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_flash_obj { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0); | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_dnd_box { | ||||
| 	position: absolute; | ||||
| 	left: 0px; | ||||
| 	top: 0px; | ||||
| 	width: 100px; | ||||
| 	height: 100px; | ||||
| 	border: 2px dashed #c0c0c0; | ||||
| 	background-color: #ffffff; | ||||
| 	opacity: 0.75; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=75); | ||||
| 	overflow: hidden; | ||||
| 	z-index: 1; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_dnd_box_text { | ||||
| 	font-size: 16px; | ||||
| 	text-align: center; | ||||
| } | ||||
| .dhx_vault_dhx_web div.dhx_vault_files.dhx_vault_dnd_box_over { | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhx_vault_dhx_web.dhx_vault_dis { | ||||
| 	background-color: #f7f7f7; | ||||
| } | ||||
| .dhx_vault_dhx_web.dhx_vault_dis div.dhx_vault_files { | ||||
| 	border-color: #a9a9a9; | ||||
| } | ||||
| .dhx_vault_dhx_web.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_button { | ||||
| 	cursor: default; | ||||
| 	opacity: 0.5; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_dhx_web.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file { | ||||
| 	opacity: 0.5; | ||||
| 	filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50); | ||||
| } | ||||
| .dhx_vault_dhx_web.dhx_vault_dis div.dhx_vault_files div.dhx_vault_file_param.dhx_vault_file_delete { | ||||
| 	cursor: default; | ||||
| } | ||||
| .dhx_vault_dhx_web.dhx_vault_dis div.dhx_vault_controls div.dhx_vault_file_form_cont { | ||||
| 	display: none; | ||||
| } | ||||
| .dhxvault_dframe { | ||||
| 	position: absolute; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 1px; | ||||
| 	height: 1px; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| .dhxvault_skin_detect { | ||||
| 	position: absolute; | ||||
| 	display: block; | ||||
| 	visibility: hidden; | ||||
| 	left: -100px; | ||||
| 	top: 0px; | ||||
| 	width: 20px; | ||||
| 	height: 10px; | ||||
| 	margin: 0px; | ||||
| 	padding: 0px; | ||||
| 	border: none; | ||||
| 	overflow: hidden; | ||||
| } | ||||
| @ -1,777 +0,0 @@ | ||||
| /*!	SWFObject v2.2 <http://code.google.com/p/swfobject/>  | ||||
| 	is released under the MIT License <http://www.opensource.org/licenses/mit-license.php>  | ||||
| */ | ||||
|  | ||||
| var swfobject = function() { | ||||
| 	 | ||||
| 	var UNDEF = "undefined", | ||||
| 		OBJECT = "object", | ||||
| 		SHOCKWAVE_FLASH = "Shockwave Flash", | ||||
| 		SHOCKWAVE_FLASH_AX = "ShockwaveFlash.ShockwaveFlash", | ||||
| 		FLASH_MIME_TYPE = "application/x-shockwave-flash", | ||||
| 		EXPRESS_INSTALL_ID = "SWFObjectExprInst", | ||||
| 		ON_READY_STATE_CHANGE = "onreadystatechange", | ||||
| 		 | ||||
| 		win = window, | ||||
| 		doc = document, | ||||
| 		nav = navigator, | ||||
| 		 | ||||
| 		plugin = false, | ||||
| 		domLoadFnArr = [main], | ||||
| 		regObjArr = [], | ||||
| 		objIdArr = [], | ||||
| 		listenersArr = [], | ||||
| 		storedAltContent, | ||||
| 		storedAltContentId, | ||||
| 		storedCallbackFn, | ||||
| 		storedCallbackObj, | ||||
| 		isDomLoaded = false, | ||||
| 		isExpressInstallActive = false, | ||||
| 		dynamicStylesheet, | ||||
| 		dynamicStylesheetMedia, | ||||
| 		autoHideShow = true, | ||||
| 	 | ||||
| 	/* Centralized function for browser feature detection | ||||
| 		- User agent string detection is only used when no good alternative is possible | ||||
| 		- Is executed directly for optimal performance | ||||
| 	*/	 | ||||
| 	ua = function() { | ||||
| 		var w3cdom = typeof doc.getElementById != UNDEF && typeof doc.getElementsByTagName != UNDEF && typeof doc.createElement != UNDEF, | ||||
| 			u = nav.userAgent.toLowerCase(), | ||||
| 			p = nav.platform.toLowerCase(), | ||||
| 			windows = p ? /win/.test(p) : /win/.test(u), | ||||
| 			mac = p ? /mac/.test(p) : /mac/.test(u), | ||||
| 			webkit = /webkit/.test(u) ? parseFloat(u.replace(/^.*webkit\/(\d+(\.\d+)?).*$/, "$1")) : false, // returns either the webkit version or false if not webkit | ||||
| 			ie = !+"\v1", // feature detection based on Andrea Giammarchi's solution: http://webreflection.blogspot.com/2009/01/32-bytes-to-know-if-your-browser-is-ie.html | ||||
| 			playerVersion = [0,0,0], | ||||
| 			d = null; | ||||
| 		if (typeof nav.plugins != UNDEF && typeof nav.plugins[SHOCKWAVE_FLASH] == OBJECT) { | ||||
| 			d = nav.plugins[SHOCKWAVE_FLASH].description; | ||||
| 			if (d && !(typeof nav.mimeTypes != UNDEF && nav.mimeTypes[FLASH_MIME_TYPE] && !nav.mimeTypes[FLASH_MIME_TYPE].enabledPlugin)) { // navigator.mimeTypes["application/x-shockwave-flash"].enabledPlugin indicates whether plug-ins are enabled or disabled in Safari 3+ | ||||
| 				plugin = true; | ||||
| 				ie = false; // cascaded feature detection for Internet Explorer | ||||
| 				d = d.replace(/^.*\s+(\S+\s+\S+$)/, "$1"); | ||||
| 				playerVersion[0] = parseInt(d.replace(/^(.*)\..*$/, "$1"), 10); | ||||
| 				playerVersion[1] = parseInt(d.replace(/^.*\.(.*)\s.*$/, "$1"), 10); | ||||
| 				playerVersion[2] = /[a-zA-Z]/.test(d) ? parseInt(d.replace(/^.*[a-zA-Z]+(.*)$/, "$1"), 10) : 0; | ||||
| 			} | ||||
| 		} | ||||
| 		else if (typeof win.ActiveXObject != UNDEF) { | ||||
| 			try { | ||||
| 				var a = new ActiveXObject(SHOCKWAVE_FLASH_AX); | ||||
| 				if (a) { // a will return null when ActiveX is disabled | ||||
| 					d = a.GetVariable("$version"); | ||||
| 					if (d) { | ||||
| 						ie = true; // cascaded feature detection for Internet Explorer | ||||
| 						d = d.split(" ")[1].split(","); | ||||
| 						playerVersion = [parseInt(d[0], 10), parseInt(d[1], 10), parseInt(d[2], 10)]; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			catch(e) {} | ||||
| 		} | ||||
| 		return { w3:w3cdom, pv:playerVersion, wk:webkit, ie:ie, win:windows, mac:mac }; | ||||
| 	}(), | ||||
| 	 | ||||
| 	/* Cross-browser onDomLoad | ||||
| 		- Will fire an event as soon as the DOM of a web page is loaded | ||||
| 		- Internet Explorer workaround based on Diego Perini's solution: http://javascript.nwbox.com/IEContentLoaded/ | ||||
| 		- Regular onload serves as fallback | ||||
| 	*/  | ||||
| 	onDomLoad = function() { | ||||
| 		if (!ua.w3) { return; } | ||||
| 		if ((typeof doc.readyState != UNDEF && doc.readyState == "complete") || (typeof doc.readyState == UNDEF && (doc.getElementsByTagName("body")[0] || doc.body))) { // function is fired after onload, e.g. when script is inserted dynamically  | ||||
| 			callDomLoadFunctions(); | ||||
| 		} | ||||
| 		if (!isDomLoaded) { | ||||
| 			if (typeof doc.addEventListener != UNDEF) { | ||||
| 				doc.addEventListener("DOMContentLoaded", callDomLoadFunctions, false); | ||||
| 			}		 | ||||
| 			if (ua.ie && ua.win) { | ||||
| 				doc.attachEvent(ON_READY_STATE_CHANGE, function() { | ||||
| 					if (doc.readyState == "complete") { | ||||
| 						doc.detachEvent(ON_READY_STATE_CHANGE, arguments.callee); | ||||
| 						callDomLoadFunctions(); | ||||
| 					} | ||||
| 				}); | ||||
| 				if (win == top) { // if not inside an iframe | ||||
| 					(function(){ | ||||
| 						if (isDomLoaded) { return; } | ||||
| 						try { | ||||
| 							doc.documentElement.doScroll("left"); | ||||
| 						} | ||||
| 						catch(e) { | ||||
| 							setTimeout(arguments.callee, 0); | ||||
| 							return; | ||||
| 						} | ||||
| 						callDomLoadFunctions(); | ||||
| 					})(); | ||||
| 				} | ||||
| 			} | ||||
| 			if (ua.wk) { | ||||
| 				(function(){ | ||||
| 					if (isDomLoaded) { return; } | ||||
| 					if (!/loaded|complete/.test(doc.readyState)) { | ||||
| 						setTimeout(arguments.callee, 0); | ||||
| 						return; | ||||
| 					} | ||||
| 					callDomLoadFunctions(); | ||||
| 				})(); | ||||
| 			} | ||||
| 			addLoadEvent(callDomLoadFunctions); | ||||
| 		} | ||||
| 	}(); | ||||
| 	 | ||||
| 	function callDomLoadFunctions() { | ||||
| 		if (isDomLoaded) { return; } | ||||
| 		try { // test if we can really add/remove elements to/from the DOM; we don't want to fire it too early | ||||
| 			var t = doc.getElementsByTagName("body")[0].appendChild(createElement("span")); | ||||
| 			t.parentNode.removeChild(t); | ||||
| 		} | ||||
| 		catch (e) { return; } | ||||
| 		isDomLoaded = true; | ||||
| 		var dl = domLoadFnArr.length; | ||||
| 		for (var i = 0; i < dl; i++) { | ||||
| 			domLoadFnArr[i](); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	function addDomLoadEvent(fn) { | ||||
| 		if (isDomLoaded) { | ||||
| 			fn(); | ||||
| 		} | ||||
| 		else {  | ||||
| 			domLoadFnArr[domLoadFnArr.length] = fn; // Array.push() is only available in IE5.5+ | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	/* Cross-browser onload | ||||
| 		- Based on James Edwards' solution: http://brothercake.com/site/resources/scripts/onload/ | ||||
| 		- Will fire an event as soon as a web page including all of its assets are loaded  | ||||
| 	 */ | ||||
| 	function addLoadEvent(fn) { | ||||
| 		if (typeof win.addEventListener != UNDEF) { | ||||
| 			win.addEventListener("load", fn, false); | ||||
| 		} | ||||
| 		else if (typeof doc.addEventListener != UNDEF) { | ||||
| 			doc.addEventListener("load", fn, false); | ||||
| 		} | ||||
| 		else if (typeof win.attachEvent != UNDEF) { | ||||
| 			addListener(win, "onload", fn); | ||||
| 		} | ||||
| 		else if (typeof win.onload == "function") { | ||||
| 			var fnOld = win.onload; | ||||
| 			win.onload = function() { | ||||
| 				fnOld(); | ||||
| 				fn(); | ||||
| 			}; | ||||
| 		} | ||||
| 		else { | ||||
| 			win.onload = fn; | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	/* Main function | ||||
| 		- Will preferably execute onDomLoad, otherwise onload (as a fallback) | ||||
| 	*/ | ||||
| 	function main() {  | ||||
| 		if (plugin) { | ||||
| 			testPlayerVersion(); | ||||
| 		} | ||||
| 		else { | ||||
| 			matchVersions(); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	/* Detect the Flash Player version for non-Internet Explorer browsers | ||||
| 		- Detecting the plug-in version via the object element is more precise than using the plugins collection item's description: | ||||
| 		  a. Both release and build numbers can be detected | ||||
| 		  b. Avoid wrong descriptions by corrupt installers provided by Adobe | ||||
| 		  c. Avoid wrong descriptions by multiple Flash Player entries in the plugin Array, caused by incorrect browser imports | ||||
| 		- Disadvantage of this method is that it depends on the availability of the DOM, while the plugins collection is immediately available | ||||
| 	*/ | ||||
| 	function testPlayerVersion() { | ||||
| 		var b = doc.getElementsByTagName("body")[0]; | ||||
| 		var o = createElement(OBJECT); | ||||
| 		o.setAttribute("type", FLASH_MIME_TYPE); | ||||
| 		var t = b.appendChild(o); | ||||
| 		if (t) { | ||||
| 			var counter = 0; | ||||
| 			(function(){ | ||||
| 				if (typeof t.GetVariable != UNDEF) { | ||||
| 					var d = t.GetVariable("$version"); | ||||
| 					if (d) { | ||||
| 						d = d.split(" ")[1].split(","); | ||||
| 						ua.pv = [parseInt(d[0], 10), parseInt(d[1], 10), parseInt(d[2], 10)]; | ||||
| 					} | ||||
| 				} | ||||
| 				else if (counter < 10) { | ||||
| 					counter++; | ||||
| 					setTimeout(arguments.callee, 10); | ||||
| 					return; | ||||
| 				} | ||||
| 				b.removeChild(o); | ||||
| 				t = null; | ||||
| 				matchVersions(); | ||||
| 			})(); | ||||
| 		} | ||||
| 		else { | ||||
| 			matchVersions(); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	/* Perform Flash Player and SWF version matching; static publishing only | ||||
| 	*/ | ||||
| 	function matchVersions() { | ||||
| 		var rl = regObjArr.length; | ||||
| 		if (rl > 0) { | ||||
| 			for (var i = 0; i < rl; i++) { // for each registered object element | ||||
| 				var id = regObjArr[i].id; | ||||
| 				var cb = regObjArr[i].callbackFn; | ||||
| 				var cbObj = {success:false, id:id}; | ||||
| 				if (ua.pv[0] > 0) { | ||||
| 					var obj = getElementById(id); | ||||
| 					if (obj) { | ||||
| 						if (hasPlayerVersion(regObjArr[i].swfVersion) && !(ua.wk && ua.wk < 312)) { // Flash Player version >= published SWF version: Houston, we have a match! | ||||
| 							setVisibility(id, true); | ||||
| 							if (cb) { | ||||
| 								cbObj.success = true; | ||||
| 								cbObj.ref = getObjectById(id); | ||||
| 								cb(cbObj); | ||||
| 							} | ||||
| 						} | ||||
| 						else if (regObjArr[i].expressInstall && canExpressInstall()) { // show the Adobe Express Install dialog if set by the web page author and if supported | ||||
| 							var att = {}; | ||||
| 							att.data = regObjArr[i].expressInstall; | ||||
| 							att.width = obj.getAttribute("width") || "0"; | ||||
| 							att.height = obj.getAttribute("height") || "0"; | ||||
| 							if (obj.getAttribute("class")) { att.styleclass = obj.getAttribute("class"); } | ||||
| 							if (obj.getAttribute("align")) { att.align = obj.getAttribute("align"); } | ||||
| 							// parse HTML object param element's name-value pairs | ||||
| 							var par = {}; | ||||
| 							var p = obj.getElementsByTagName("param"); | ||||
| 							var pl = p.length; | ||||
| 							for (var j = 0; j < pl; j++) { | ||||
| 								if (p[j].getAttribute("name").toLowerCase() != "movie") { | ||||
| 									par[p[j].getAttribute("name")] = p[j].getAttribute("value"); | ||||
| 								} | ||||
| 							} | ||||
| 							showExpressInstall(att, par, id, cb); | ||||
| 						} | ||||
| 						else { // Flash Player and SWF version mismatch or an older Webkit engine that ignores the HTML object element's nested param elements: display alternative content instead of SWF | ||||
| 							displayAltContent(obj); | ||||
| 							if (cb) { cb(cbObj); } | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 				else {	// if no Flash Player is installed or the fp version cannot be detected we let the HTML object element do its job (either show a SWF or alternative content) | ||||
| 					setVisibility(id, true); | ||||
| 					if (cb) { | ||||
| 						var o = getObjectById(id); // test whether there is an HTML object element or not | ||||
| 						if (o && typeof o.SetVariable != UNDEF) {  | ||||
| 							cbObj.success = true; | ||||
| 							cbObj.ref = o; | ||||
| 						} | ||||
| 						cb(cbObj); | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	function getObjectById(objectIdStr) { | ||||
| 		var r = null; | ||||
| 		var o = getElementById(objectIdStr); | ||||
| 		if (o && o.nodeName == "OBJECT") { | ||||
| 			if (typeof o.SetVariable != UNDEF) { | ||||
| 				r = o; | ||||
| 			} | ||||
| 			else { | ||||
| 				var n = o.getElementsByTagName(OBJECT)[0]; | ||||
| 				if (n) { | ||||
| 					r = n; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		return r; | ||||
| 	} | ||||
| 	 | ||||
| 	/* Requirements for Adobe Express Install | ||||
| 		- only one instance can be active at a time | ||||
| 		- fp 6.0.65 or higher | ||||
| 		- Win/Mac OS only | ||||
| 		- no Webkit engines older than version 312 | ||||
| 	*/ | ||||
| 	function canExpressInstall() { | ||||
| 		return !isExpressInstallActive && hasPlayerVersion("6.0.65") && (ua.win || ua.mac) && !(ua.wk && ua.wk < 312); | ||||
| 	} | ||||
| 	 | ||||
| 	/* Show the Adobe Express Install dialog | ||||
| 		- Reference: http://www.adobe.com/cfusion/knowledgebase/index.cfm?id=6a253b75 | ||||
| 	*/ | ||||
| 	function showExpressInstall(att, par, replaceElemIdStr, callbackFn) { | ||||
| 		isExpressInstallActive = true; | ||||
| 		storedCallbackFn = callbackFn || null; | ||||
| 		storedCallbackObj = {success:false, id:replaceElemIdStr}; | ||||
| 		var obj = getElementById(replaceElemIdStr); | ||||
| 		if (obj) { | ||||
| 			if (obj.nodeName == "OBJECT") { // static publishing | ||||
| 				storedAltContent = abstractAltContent(obj); | ||||
| 				storedAltContentId = null; | ||||
| 			} | ||||
| 			else { // dynamic publishing | ||||
| 				storedAltContent = obj; | ||||
| 				storedAltContentId = replaceElemIdStr; | ||||
| 			} | ||||
| 			att.id = EXPRESS_INSTALL_ID; | ||||
| 			if (typeof att.width == UNDEF || (!/%$/.test(att.width) && parseInt(att.width, 10) < 310)) { att.width = "310"; } | ||||
| 			if (typeof att.height == UNDEF || (!/%$/.test(att.height) && parseInt(att.height, 10) < 137)) { att.height = "137"; } | ||||
| 			doc.title = doc.title.slice(0, 47) + " - Flash Player Installation"; | ||||
| 			var pt = ua.ie && ua.win ? "ActiveX" : "PlugIn", | ||||
| 				fv = "MMredirectURL=" + encodeURI(window.location).toString().replace(/&/g,"%26") + "&MMplayerType=" + pt + "&MMdoctitle=" + doc.title; | ||||
| 			if (typeof par.flashvars != UNDEF) { | ||||
| 				par.flashvars += "&" + fv; | ||||
| 			} | ||||
| 			else { | ||||
| 				par.flashvars = fv; | ||||
| 			} | ||||
| 			// IE only: when a SWF is loading (AND: not available in cache) wait for the readyState of the object element to become 4 before removing it, | ||||
| 			// because you cannot properly cancel a loading SWF file without breaking browser load references, also obj.onreadystatechange doesn't work | ||||
| 			if (ua.ie && ua.win && obj.readyState != 4) { | ||||
| 				var newObj = createElement("div"); | ||||
| 				replaceElemIdStr += "SWFObjectNew"; | ||||
| 				newObj.setAttribute("id", replaceElemIdStr); | ||||
| 				obj.parentNode.insertBefore(newObj, obj); // insert placeholder div that will be replaced by the object element that loads expressinstall.swf | ||||
| 				obj.style.display = "none"; | ||||
| 				(function(){ | ||||
| 					if (obj.readyState == 4) { | ||||
| 						obj.parentNode.removeChild(obj); | ||||
| 					} | ||||
| 					else { | ||||
| 						setTimeout(arguments.callee, 10); | ||||
| 					} | ||||
| 				})(); | ||||
| 			} | ||||
| 			createSWF(att, par, replaceElemIdStr); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	/* Functions to abstract and display alternative content | ||||
| 	*/ | ||||
| 	function displayAltContent(obj) { | ||||
| 		if (ua.ie && ua.win && obj.readyState != 4) { | ||||
| 			// IE only: when a SWF is loading (AND: not available in cache) wait for the readyState of the object element to become 4 before removing it, | ||||
| 			// because you cannot properly cancel a loading SWF file without breaking browser load references, also obj.onreadystatechange doesn't work | ||||
| 			var el = createElement("div"); | ||||
| 			obj.parentNode.insertBefore(el, obj); // insert placeholder div that will be replaced by the alternative content | ||||
| 			el.parentNode.replaceChild(abstractAltContent(obj), el); | ||||
| 			obj.style.display = "none"; | ||||
| 			(function(){ | ||||
| 				if (obj.readyState == 4) { | ||||
| 					obj.parentNode.removeChild(obj); | ||||
| 				} | ||||
| 				else { | ||||
| 					setTimeout(arguments.callee, 10); | ||||
| 				} | ||||
| 			})(); | ||||
| 		} | ||||
| 		else { | ||||
| 			obj.parentNode.replaceChild(abstractAltContent(obj), obj); | ||||
| 		} | ||||
| 	}  | ||||
|  | ||||
| 	function abstractAltContent(obj) { | ||||
| 		var ac = createElement("div"); | ||||
| 		if (ua.win && ua.ie) { | ||||
| 			ac.innerHTML = obj.innerHTML; | ||||
| 		} | ||||
| 		else { | ||||
| 			var nestedObj = obj.getElementsByTagName(OBJECT)[0]; | ||||
| 			if (nestedObj) { | ||||
| 				var c = nestedObj.childNodes; | ||||
| 				if (c) { | ||||
| 					var cl = c.length; | ||||
| 					for (var i = 0; i < cl; i++) { | ||||
| 						if (!(c[i].nodeType == 1 && c[i].nodeName == "PARAM") && !(c[i].nodeType == 8)) { | ||||
| 							ac.appendChild(c[i].cloneNode(true)); | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		return ac; | ||||
| 	} | ||||
| 	 | ||||
| 	/* Cross-browser dynamic SWF creation | ||||
| 	*/ | ||||
| 	function createSWF(attObj, parObj, id) { | ||||
| 		var r, el = getElementById(id); | ||||
| 		if (ua.wk && ua.wk < 312) { return r; } | ||||
| 		if (el) { | ||||
| 			if (typeof attObj.id == UNDEF) { // if no 'id' is defined for the object element, it will inherit the 'id' from the alternative content | ||||
| 				attObj.id = id; | ||||
| 			} | ||||
| 			if (ua.ie && ua.win) { // Internet Explorer + the HTML object element + W3C DOM methods do not combine: fall back to outerHTML | ||||
| 				var att = ""; | ||||
| 				for (var i in attObj) { | ||||
| 					if (attObj[i] != Object.prototype[i]) { // filter out prototype additions from other potential libraries | ||||
| 						if (i.toLowerCase() == "data") { | ||||
| 							parObj.movie = attObj[i]; | ||||
| 						} | ||||
| 						else if (i.toLowerCase() == "styleclass") { // 'class' is an ECMA4 reserved keyword | ||||
| 							att += ' class="' + attObj[i] + '"'; | ||||
| 						} | ||||
| 						else if (i.toLowerCase() != "classid") { | ||||
| 							att += ' ' + i + '="' + attObj[i] + '"'; | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 				var par = ""; | ||||
| 				for (var j in parObj) { | ||||
| 					if (parObj[j] != Object.prototype[j]) { // filter out prototype additions from other potential libraries | ||||
| 						par += '<param name="' + j + '" value="' + parObj[j] + '" />'; | ||||
| 					} | ||||
| 				} | ||||
| 				el.outerHTML = '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"' + att + '>' + par + '</object>'; | ||||
| 				objIdArr[objIdArr.length] = attObj.id; // stored to fix object 'leaks' on unload (dynamic publishing only) | ||||
| 				r = getElementById(attObj.id);	 | ||||
| 			} | ||||
| 			else { // well-behaving browsers | ||||
| 				var o = createElement(OBJECT); | ||||
| 				o.setAttribute("type", FLASH_MIME_TYPE); | ||||
| 				for (var m in attObj) { | ||||
| 					if (attObj[m] != Object.prototype[m]) { // filter out prototype additions from other potential libraries | ||||
| 						if (m.toLowerCase() == "styleclass") { // 'class' is an ECMA4 reserved keyword | ||||
| 							o.setAttribute("class", attObj[m]); | ||||
| 						} | ||||
| 						else if (m.toLowerCase() != "classid") { // filter out IE specific attribute | ||||
| 							o.setAttribute(m, attObj[m]); | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 				for (var n in parObj) { | ||||
| 					if (parObj[n] != Object.prototype[n] && n.toLowerCase() != "movie") { // filter out prototype additions from other potential libraries and IE specific param element | ||||
| 						createObjParam(o, n, parObj[n]); | ||||
| 					} | ||||
| 				} | ||||
| 				el.parentNode.replaceChild(o, el); | ||||
| 				r = o; | ||||
| 			} | ||||
| 		} | ||||
| 		return r; | ||||
| 	} | ||||
| 	 | ||||
| 	function createObjParam(el, pName, pValue) { | ||||
| 		var p = createElement("param"); | ||||
| 		p.setAttribute("name", pName);	 | ||||
| 		p.setAttribute("value", pValue); | ||||
| 		el.appendChild(p); | ||||
| 	} | ||||
| 	 | ||||
| 	/* Cross-browser SWF removal | ||||
| 		- Especially needed to safely and completely remove a SWF in Internet Explorer | ||||
| 	*/ | ||||
| 	function removeSWF(id) { | ||||
| 		var obj = getElementById(id); | ||||
| 		if (obj && obj.nodeName == "OBJECT") { | ||||
| 			if (ua.ie && ua.win) { | ||||
| 				obj.style.display = "none"; | ||||
| 				(function(){ | ||||
| 					if (obj.readyState == 4) { | ||||
| 						removeObjectInIE(id); | ||||
| 					} | ||||
| 					else { | ||||
| 						setTimeout(arguments.callee, 10); | ||||
| 					} | ||||
| 				})(); | ||||
| 			} | ||||
| 			else { | ||||
| 				obj.parentNode.removeChild(obj); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	function removeObjectInIE(id) { | ||||
| 		var obj = getElementById(id); | ||||
| 		if (obj) { | ||||
| 			for (var i in obj) { | ||||
| 				if (typeof obj[i] == "function") { | ||||
| 					obj[i] = null; | ||||
| 				} | ||||
| 			} | ||||
| 			obj.parentNode.removeChild(obj); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	/* Functions to optimize JavaScript compression | ||||
| 	*/ | ||||
| 	function getElementById(id) { | ||||
| 		var el = null; | ||||
| 		try { | ||||
| 			el = doc.getElementById(id); | ||||
| 		} | ||||
| 		catch (e) {} | ||||
| 		return el; | ||||
| 	} | ||||
| 	 | ||||
| 	function createElement(el) { | ||||
| 		return doc.createElement(el); | ||||
| 	} | ||||
| 	 | ||||
| 	/* Updated attachEvent function for Internet Explorer | ||||
| 		- Stores attachEvent information in an Array, so on unload the detachEvent functions can be called to avoid memory leaks | ||||
| 	*/	 | ||||
| 	function addListener(target, eventType, fn) { | ||||
| 		target.attachEvent(eventType, fn); | ||||
| 		listenersArr[listenersArr.length] = [target, eventType, fn]; | ||||
| 	} | ||||
| 	 | ||||
| 	/* Flash Player and SWF content version matching | ||||
| 	*/ | ||||
| 	function hasPlayerVersion(rv) { | ||||
| 		var pv = ua.pv, v = rv.split("."); | ||||
| 		v[0] = parseInt(v[0], 10); | ||||
| 		v[1] = parseInt(v[1], 10) || 0; // supports short notation, e.g. "9" instead of "9.0.0" | ||||
| 		v[2] = parseInt(v[2], 10) || 0; | ||||
| 		return (pv[0] > v[0] || (pv[0] == v[0] && pv[1] > v[1]) || (pv[0] == v[0] && pv[1] == v[1] && pv[2] >= v[2])) ? true : false; | ||||
| 	} | ||||
| 	 | ||||
| 	/* Cross-browser dynamic CSS creation | ||||
| 		- Based on Bobby van der Sluis' solution: http://www.bobbyvandersluis.com/articles/dynamicCSS.php | ||||
| 	*/	 | ||||
| 	function createCSS(sel, decl, media, newStyle) { | ||||
| 		if (ua.ie && ua.mac) { return; } | ||||
| 		var h = doc.getElementsByTagName("head")[0]; | ||||
| 		if (!h) { return; } // to also support badly authored HTML pages that lack a head element | ||||
| 		var m = (media && typeof media == "string") ? media : "screen"; | ||||
| 		if (newStyle) { | ||||
| 			dynamicStylesheet = null; | ||||
| 			dynamicStylesheetMedia = null; | ||||
| 		} | ||||
| 		if (!dynamicStylesheet || dynamicStylesheetMedia != m) {  | ||||
| 			// create dynamic stylesheet + get a global reference to it | ||||
| 			var s = createElement("style"); | ||||
| 			s.setAttribute("type", "text/css"); | ||||
| 			s.setAttribute("media", m); | ||||
| 			dynamicStylesheet = h.appendChild(s); | ||||
| 			if (ua.ie && ua.win && typeof doc.styleSheets != UNDEF && doc.styleSheets.length > 0) { | ||||
| 				dynamicStylesheet = doc.styleSheets[doc.styleSheets.length - 1]; | ||||
| 			} | ||||
| 			dynamicStylesheetMedia = m; | ||||
| 		} | ||||
| 		// add style rule | ||||
| 		if (ua.ie && ua.win) { | ||||
| 			if (dynamicStylesheet && typeof dynamicStylesheet.addRule == OBJECT) { | ||||
| 				dynamicStylesheet.addRule(sel, decl); | ||||
| 			} | ||||
| 		} | ||||
| 		else { | ||||
| 			if (dynamicStylesheet && typeof doc.createTextNode != UNDEF) { | ||||
| 				dynamicStylesheet.appendChild(doc.createTextNode(sel + " {" + decl + "}")); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	function setVisibility(id, isVisible) { | ||||
| 		if (!autoHideShow) { return; } | ||||
| 		var v = isVisible ? "visible" : "hidden"; | ||||
| 		if (isDomLoaded && getElementById(id)) { | ||||
| 			getElementById(id).style.visibility = v; | ||||
| 		} | ||||
| 		else { | ||||
| 			createCSS("#" + id, "visibility:" + v); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/* Filter to avoid XSS attacks | ||||
| 	*/ | ||||
| 	function urlEncodeIfNecessary(s) { | ||||
| 		var regex = /[\\\"<>\.;]/; | ||||
| 		var hasBadChars = regex.exec(s) != null; | ||||
| 		return hasBadChars && typeof encodeURIComponent != UNDEF ? encodeURIComponent(s) : s; | ||||
| 	} | ||||
| 	 | ||||
| 	/* Release memory to avoid memory leaks caused by closures, fix hanging audio/video threads and force open sockets/NetConnections to disconnect (Internet Explorer only) | ||||
| 	*/ | ||||
| 	var cleanup = function() { | ||||
| 		if (ua.ie && ua.win) { | ||||
| 			window.attachEvent("onunload", function() { | ||||
| 				// remove listeners to avoid memory leaks | ||||
| 				var ll = listenersArr.length; | ||||
| 				for (var i = 0; i < ll; i++) { | ||||
| 					listenersArr[i][0].detachEvent(listenersArr[i][1], listenersArr[i][2]); | ||||
| 				} | ||||
| 				// cleanup dynamically embedded objects to fix audio/video threads and force open sockets and NetConnections to disconnect | ||||
| 				var il = objIdArr.length; | ||||
| 				for (var j = 0; j < il; j++) { | ||||
| 					removeSWF(objIdArr[j]); | ||||
| 				} | ||||
| 				// cleanup library's main closures to avoid memory leaks | ||||
| 				for (var k in ua) { | ||||
| 					ua[k] = null; | ||||
| 				} | ||||
| 				ua = null; | ||||
| 				for (var l in swfobject) { | ||||
| 					swfobject[l] = null; | ||||
| 				} | ||||
| 				swfobject = null; | ||||
| 			}); | ||||
| 		} | ||||
| 	}(); | ||||
| 	 | ||||
| 	return { | ||||
| 		/* Public API | ||||
| 			- Reference: http://code.google.com/p/swfobject/wiki/documentation | ||||
| 		*/  | ||||
| 		registerObject: function(objectIdStr, swfVersionStr, xiSwfUrlStr, callbackFn) { | ||||
| 			if (ua.w3 && objectIdStr && swfVersionStr) { | ||||
| 				var regObj = {}; | ||||
| 				regObj.id = objectIdStr; | ||||
| 				regObj.swfVersion = swfVersionStr; | ||||
| 				regObj.expressInstall = xiSwfUrlStr; | ||||
| 				regObj.callbackFn = callbackFn; | ||||
| 				regObjArr[regObjArr.length] = regObj; | ||||
| 				setVisibility(objectIdStr, false); | ||||
| 			} | ||||
| 			else if (callbackFn) { | ||||
| 				callbackFn({success:false, id:objectIdStr}); | ||||
| 			} | ||||
| 		}, | ||||
| 		 | ||||
| 		getObjectById: function(objectIdStr) { | ||||
| 			if (ua.w3) { | ||||
| 				return getObjectById(objectIdStr); | ||||
| 			} | ||||
| 		}, | ||||
| 		 | ||||
| 		embedSWF: function(swfUrlStr, replaceElemIdStr, widthStr, heightStr, swfVersionStr, xiSwfUrlStr, flashvarsObj, parObj, attObj, callbackFn) { | ||||
| 			var callbackObj = {success:false, id:replaceElemIdStr}; | ||||
| 			if (ua.w3 && !(ua.wk && ua.wk < 312) && swfUrlStr && replaceElemIdStr && widthStr && heightStr && swfVersionStr) { | ||||
| 				setVisibility(replaceElemIdStr, false); | ||||
| 				addDomLoadEvent(function() { | ||||
| 					widthStr += ""; // auto-convert to string | ||||
| 					heightStr += ""; | ||||
| 					var att = {}; | ||||
| 					if (attObj && typeof attObj === OBJECT) { | ||||
| 						for (var i in attObj) { // copy object to avoid the use of references, because web authors often reuse attObj for multiple SWFs | ||||
| 							att[i] = attObj[i]; | ||||
| 						} | ||||
| 					} | ||||
| 					att.data = swfUrlStr; | ||||
| 					att.width = widthStr; | ||||
| 					att.height = heightStr; | ||||
| 					var par = {};  | ||||
| 					if (parObj && typeof parObj === OBJECT) { | ||||
| 						for (var j in parObj) { // copy object to avoid the use of references, because web authors often reuse parObj for multiple SWFs | ||||
| 							par[j] = parObj[j]; | ||||
| 						} | ||||
| 					} | ||||
| 					if (flashvarsObj && typeof flashvarsObj === OBJECT) { | ||||
| 						for (var k in flashvarsObj) { // copy object to avoid the use of references, because web authors often reuse flashvarsObj for multiple SWFs | ||||
| 							if (typeof par.flashvars != UNDEF) { | ||||
| 								par.flashvars += "&" + k + "=" + flashvarsObj[k]; | ||||
| 							} | ||||
| 							else { | ||||
| 								par.flashvars = k + "=" + flashvarsObj[k]; | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 					if (hasPlayerVersion(swfVersionStr)) { // create SWF | ||||
| 						var obj = createSWF(att, par, replaceElemIdStr); | ||||
| 						if (att.id == replaceElemIdStr) { | ||||
| 							setVisibility(replaceElemIdStr, true); | ||||
| 						} | ||||
| 						callbackObj.success = true; | ||||
| 						callbackObj.ref = obj; | ||||
| 					} | ||||
| 					else if (xiSwfUrlStr && canExpressInstall()) { // show Adobe Express Install | ||||
| 						att.data = xiSwfUrlStr; | ||||
| 						showExpressInstall(att, par, replaceElemIdStr, callbackFn); | ||||
| 						return; | ||||
| 					} | ||||
| 					else { // show alternative content | ||||
| 						setVisibility(replaceElemIdStr, true); | ||||
| 					} | ||||
| 					if (callbackFn) { callbackFn(callbackObj); } | ||||
| 				}); | ||||
| 			} | ||||
| 			else if (callbackFn) { callbackFn(callbackObj);	} | ||||
| 		}, | ||||
| 		 | ||||
| 		switchOffAutoHideShow: function() { | ||||
| 			autoHideShow = false; | ||||
| 		}, | ||||
| 		 | ||||
| 		ua: ua, | ||||
| 		 | ||||
| 		getFlashPlayerVersion: function() { | ||||
| 			return { major:ua.pv[0], minor:ua.pv[1], release:ua.pv[2] }; | ||||
| 		}, | ||||
| 		 | ||||
| 		hasFlashPlayerVersion: hasPlayerVersion, | ||||
| 		 | ||||
| 		createSWF: function(attObj, parObj, replaceElemIdStr) { | ||||
| 			if (ua.w3) { | ||||
| 				return createSWF(attObj, parObj, replaceElemIdStr); | ||||
| 			} | ||||
| 			else { | ||||
| 				return undefined; | ||||
| 			} | ||||
| 		}, | ||||
| 		 | ||||
| 		showExpressInstall: function(att, par, replaceElemIdStr, callbackFn) { | ||||
| 			if (ua.w3 && canExpressInstall()) { | ||||
| 				showExpressInstall(att, par, replaceElemIdStr, callbackFn); | ||||
| 			} | ||||
| 		}, | ||||
| 		 | ||||
| 		removeSWF: function(objElemIdStr) { | ||||
| 			if (ua.w3) { | ||||
| 				removeSWF(objElemIdStr); | ||||
| 			} | ||||
| 		}, | ||||
| 		 | ||||
| 		createCSS: function(selStr, declStr, mediaStr, newStyleBoolean) { | ||||
| 			if (ua.w3) { | ||||
| 				createCSS(selStr, declStr, mediaStr, newStyleBoolean); | ||||
| 			} | ||||
| 		}, | ||||
| 		 | ||||
| 		addDomLoadEvent: addDomLoadEvent, | ||||
| 		 | ||||
| 		addLoadEvent: addLoadEvent, | ||||
| 		 | ||||
| 		getQueryParamValue: function(param) { | ||||
| 			var q = doc.location.search || doc.location.hash; | ||||
| 			if (q) { | ||||
| 				if (/\?/.test(q)) { q = q.split("?")[1]; } // strip question mark | ||||
| 				if (param == null) { | ||||
| 					return urlEncodeIfNecessary(q); | ||||
| 				} | ||||
| 				var pairs = q.split("&"); | ||||
| 				for (var i = 0; i < pairs.length; i++) { | ||||
| 					if (pairs[i].substring(0, pairs[i].indexOf("=")) == param) { | ||||
| 						return urlEncodeIfNecessary(pairs[i].substring((pairs[i].indexOf("=") + 1))); | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			return ""; | ||||
| 		}, | ||||
| 		 | ||||
| 		// For internal usage only | ||||
| 		expressInstallCallback: function() { | ||||
| 			if (isExpressInstallActive) { | ||||
| 				var obj = getElementById(EXPRESS_INSTALL_ID); | ||||
| 				if (obj && storedAltContent) { | ||||
| 					obj.parentNode.replaceChild(storedAltContent, obj); | ||||
| 					if (storedAltContentId) { | ||||
| 						setVisibility(storedAltContentId, true); | ||||
| 						if (ua.ie && ua.win) { storedAltContent.style.display = "block"; } | ||||
| 					} | ||||
| 					if (storedCallbackFn) { storedCallbackFn(storedCallbackObj); } | ||||
| 				} | ||||
| 				isExpressInstallActive = false; | ||||
| 			}  | ||||
| 		} | ||||
| 	}; | ||||
| }(); | ||||