lanan-system-vue/public/static/UEditorPlus/dialogs/wordimage/wordimage.js

94 lines
3.2 KiB
JavaScript
Raw Normal View History

2024-09-27 17:22:19 +08:00
/**
* Created by JetBrains PhpStorm.
* User: taoqili
* Date: 12-1-30
* Time: 下午12:50
* To change this template use File | Settings | File Templates.
*/
var wordImage = {};
var g = $G, flashObj, flashContainer;
wordImage.init = function (opt, callbacks) {
showLocalPath("fileUrl");
createCopyButton("copyButton", "fileUrl");
addUploadButtonListener();
addOkListener();
};
function addUploadButtonListener() {
g('saveFile').addEventListener('change', function () {
$('.image-tip').html('正在转存,请稍后...');
uploader.addFile(this.files);
uploader.upload();
});
}
function addOkListener() {
dialog.onok = function () {
//console.log('imageUrls',imageUrls);
if (!imageUrls.length) return;
var urlPrefix = editor.getOpt('imageUrlPrefix'),
images = domUtils.getElementsByTagName(editor.document, "img");
editor.fireEvent('saveScene');
// console.log('images',images,imageUrls);
for (var i = 0, img; img = images[i++];) {
var src = img.getAttribute("data-word-image");
if (!src) continue;
for (var j = 0, url; url = imageUrls[j++];) {
// console.log('url',src, url);
if (src.indexOf(url.name.replace(" ", "")) != -1) {
img.src = urlPrefix + url.url;
img.setAttribute("_src", urlPrefix + url.url); //同时修改"_src"属性
img.setAttribute("title", url.title);
domUtils.removeAttributes(img, ["data-word-image", "style", "width", "height"]);
editor.fireEvent("selectionchange");
break;
}
}
}
editor.fireEvent('saveScene');
// hideFlash();
};
dialog.oncancel = function () {
//hideFlash();
};
}
function showLocalPath(id) {
//单张编辑
var img = editor.selection.getRange().getClosedNode();
var images = editor.execCommand('wordimage');
if (images.length == 1 || img && img.tagName == 'IMG') {
g(id).value = images[0];
return;
}
var path = images[0];
var leftSlashIndex = path.lastIndexOf("/") || 0, //不同版本的doc和浏览器都可能影响到这个符号故直接判断两种
rightSlashIndex = path.lastIndexOf("\\") || 0,
separater = leftSlashIndex > rightSlashIndex ? "/" : "\\";
path = path.substring(0, path.lastIndexOf(separater) + 1);
g(id).value = path;
//增提醒用户选择哪些文件
var names = [];
for (var i = 0, len = images.length; i < len; i++) {
var img = images[i];
names.push(img.substring(img.lastIndexOf(separater) + 1, img.length));
}
$('.image-tip').html('<span style="color:#ff0000;">请选择:' + names.join("、") + "共" + images.length + '个文件</span>');
}
function createCopyButton(id, dataFrom) {
var url = g(dataFrom).value;
if (url.startsWith("file:////")) {
url = url.substring(8);
}
url = decodeURI(url);
g(id).setAttribute("data-clipboard-text", url);
var clipboard = new Clipboard('[data-clipboard-text]')
clipboard.on('success', function (e) {
g('copyButton').innerHTML = '复制成功';
});
}