123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- /**
- *
- * @version $Id: handlers.js 1 22:28 2010年7月20日Z tianya $
- * @package DedeCMS.Administrator
- * @copyright Copyright (c) 2007 - 2010, DesDev, Inc.
- * @license http://help.dedecms.com/usersguide/license.html
- * @link http://www.dedecms.com
- */
- //---事件句并------------------------------
- function fileQueueError(file, errorCode, message){
- try {
- var imageName = "error.gif";
- var errorName = "";
- if (errorCode === SWFUpload.errorCode_QUEUE_LIMIT_EXCEEDED) {
- errorName = "你添加的文件超过了限制!";
- }
- if (errorName !== "") {
- alert(errorName);
- return;
- }
- switch (errorCode) {
- case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
- imageName = "zerobyte.gif";
- break;
- case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
- imageName = "toobig.gif";
- break;
- case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
- case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
- default:
- alert(message);
- break;
- }
- addImage("images/" + imageName, 0);
- } catch (ex) {
- this.debug(ex);
- }
- }
- function fileDialogComplete(numFilesSelected, numFilesQueued) {
- try {
- if (numFilesQueued > 0) {
- this.startUpload();
- }
- } catch (ex) {
- this.debug(ex);
- }
- }
- function uploadProgress(file, bytesLoaded) {
- try {
- var percent = Math.ceil((bytesLoaded / file.size) * 100);
- var progress = new FileProgress(file, this.customSettings.upload_target);
- progress.setProgress(percent);
- if (percent === 100) {
- progress.setStatus("创建缩略图...");
- progress.toggleCancel(false, this);
- } else {
- progress.setStatus("上传中...");
- progress.toggleCancel(true, this);
- }
- } catch (ex) {
- this.debug(ex);
- }
- }
- function uploadSuccess(file, serverData) {
- try {
- var progress = new FileProgress(file, this.customSettings.upload_target);
- if (serverData.substring(0, 7) === "FILEID:") {
- addImage("swfupload.php?dopost=thumbnail&id=" + serverData.substring(7), serverData.substring(7));
- progress.setStatus("获取缩略图...");
- progress.toggleCancel(false);
- } else {
- addImage("images/error.gif", 0);
- progress.setStatus("有错误!");
- progress.toggleCancel(false);
- alert(serverData);
- }
- } catch (ex) {
- this.debug(ex);
- }
- }
- function uploadComplete(file) {
- try {
- /* I want the next upload to continue automatically so I'll call startUpload here */
- if (this.getStats().files_queued > 0) {
- this.startUpload();
- } else {
- var progress = new FileProgress(file, this.customSettings.upload_target);
- progress.setComplete();
- progress.setStatus("所有图片上传完成...");
- progress.toggleCancel(false);
- }
- } catch (ex) {
- this.debug(ex);
- }
- }
- function uploadError(file, errorCode, message) {
- var imageName = "error.gif";
- var progress;
- try {
- switch (errorCode) {
- case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
- try {
- progress = new FileProgress(file, this.customSettings.upload_target);
- progress.setCancelled();
- progress.setStatus("Cancelled");
- progress.toggleCancel(false);
- }
- catch (ex1) {
- this.debug(ex1);
- }
- break;
- case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
- try {
- progress = new FileProgress(file, this.customSettings.upload_target);
- progress.setCancelled();
- progress.setStatus("Stopped");
- progress.toggleCancel(true);
- }
- catch (ex2) {
- this.debug(ex2);
- }
- case SWFUpload.UPLOAD_ERROR.UPLOAD_LIMIT_EXCEEDED:
- imageName = "uploadlimit.gif";
- break;
- default:
- alert(message);
- break;
- }
- addImage("images/" + imageName, 0);
- } catch (ex3) {
- this.debug(ex3);
- }
- }
- var albImg = 0;
- function addImage(src, pid){
- var newImgDiv = document.createElement("div");
- var delstr = '';
- var iptwidth = 190;
- albImg++;
- if(pid != 0) {
- albImg = 'ok' + pid;
- delstr = '<a href="javascript:delAlbPic('+pid+')">[删除]</a>';
- } else {
- albImg = 'err' + albImg;
- }
- newImgDiv.className = 'albCt';
- newImgDiv.id = 'albCt'+albImg;
- document.getElementById("thumbnails").appendChild(newImgDiv);
- newImgDiv.innerHTML = '<img src="'+src+'" width="120" />'+delstr;
- if(typeof arctype != 'undefined' && arctype == 'article' )
- {
- iptwidth = 100;
- if(pid != 0) {
- newImgDiv.innerHTML = '<img src="'+src+'" width="120" onClick="addtoEdit('+pid+')"/>'+delstr;
- }
- }
- newImgDiv.innerHTML += '<div style="margin-top:10px">注释:<input type="text" name="picinfo'+albImg+'" value="" style="width:'+iptwidth+'px;" /></div>';
- }
- /* ******************************************
- * FileProgress Object
- * Control object for displaying file info
- * ****************************************** */
- function FileProgress(file, targetID) {
- this.fileProgressID = "divFileProgress";
- this.fileProgressWrapper = document.getElementById(this.fileProgressID);
- if (!this.fileProgressWrapper) {
- this.fileProgressWrapper = document.createElement("div");
- this.fileProgressWrapper.className = "progressWrapper";
- this.fileProgressWrapper.id = this.fileProgressID;
- this.fileProgressElement = document.createElement("div");
- this.fileProgressElement.className = "progressContainer";
- var progressCancel = document.createElement("a");
- progressCancel.className = "progressCancel";
- progressCancel.href = "#";
- progressCancel.style.visibility = "hidden";
- progressCancel.appendChild(document.createTextNode(" "));
- var progressText = document.createElement("div");
- progressText.className = "progressName";
- progressText.appendChild(document.createTextNode(file.name));
- var progressBar = document.createElement("div");
- progressBar.className = "progressBarInProgress";
- var progressStatus = document.createElement("div");
- progressStatus.className = "progressBarStatus";
- progressStatus.innerHTML = " ";
- this.fileProgressElement.appendChild(progressCancel);
- this.fileProgressElement.appendChild(progressText);
- this.fileProgressElement.appendChild(progressStatus);
- this.fileProgressElement.appendChild(progressBar);
- this.fileProgressWrapper.appendChild(this.fileProgressElement);
- document.getElementById(targetID).appendChild(this.fileProgressWrapper);
- } else {
- this.fileProgressElement = this.fileProgressWrapper.firstChild;
- this.fileProgressElement.childNodes[1].firstChild.nodeValue = file.name;
- }
- this.height = this.fileProgressWrapper.offsetHeight;
- }
- FileProgress.prototype.setProgress = function (percentage) {
- this.fileProgressElement.className = "progressContainer blue";
- this.fileProgressElement.childNodes[3].className = "progressBarInProgress";
- this.fileProgressElement.childNodes[3].style.width = percentage + "%";
- };
- FileProgress.prototype.setComplete = function () {
- this.fileProgressElement.className = "progressContainer green";
- this.fileProgressElement.childNodes[3].className = "progressBarComplete";
- this.fileProgressElement.childNodes[3].style.width = "";
- };
- FileProgress.prototype.setError = function () {
- this.fileProgressElement.className = "progressContainer red";
- this.fileProgressElement.childNodes[3].className = "progressBarError";
- this.fileProgressElement.childNodes[3].style.width = "";
- };
- FileProgress.prototype.setCancelled = function () {
- this.fileProgressElement.className = "progressContainer";
- this.fileProgressElement.childNodes[3].className = "progressBarError";
- this.fileProgressElement.childNodes[3].style.width = "";
- };
- FileProgress.prototype.setStatus = function (status) {
- this.fileProgressElement.childNodes[2].innerHTML = status;
- };
- FileProgress.prototype.toggleCancel = function (show, swfuploadInstance) {
- this.fileProgressElement.childNodes[0].style.visibility = show ? "visible" : "hidden";
- if (swfuploadInstance) {
- var fileID = this.fileProgressID;
- this.fileProgressElement.childNodes[0].onclick = function () {
- swfuploadInstance.cancelUpload(fileID);
- return false;
- };
- }
- };
|