define([], function () { require([], function () { //绑定data-toggle=addresspicker属性点击事件 $(document).on('click', "[data-toggle='addresspicker']", function () { var that = this; var callback = $(that).data('callback'); var input_id = $(that).data("input-id") ? $(that).data("input-id") : ""; var lat_id = $(that).data("lat-id") ? $(that).data("lat-id") : ""; var lng_id = $(that).data("lng-id") ? $(that).data("lng-id") : ""; var lat = lat_id ? $("#" + lat_id).val() : ''; var lng = lng_id ? $("#" + lng_id).val() : ''; var url = "/addons/address/index/select"; url += (lat && lng) ? '?lat=' + lat + '&lng=' + lng : ''; Fast.api.open(url, '位置选择', { callback: function (res) { input_id && $("#" + input_id).val(res.address).trigger("change"); lat_id && $("#" + lat_id).val(res.lat).trigger("change"); lng_id && $("#" + lng_id).val(res.lng).trigger("change"); try { //执行回调函数 if (typeof callback === 'function') { callback.call(that, res); } } catch (e) { } } }); }); }); require.config({ paths: { 'async': '../addons/cwmap/js/async', 'BMap3': ['//api.map.baidu.com/api?v=3.0&ak=mXijumfojHnAaN2VxpBGoqHM'], }, shim: { 'BMap3': { deps: ['jquery'], exports: 'BMap3' } } }); require.config({ paths: { 'nkeditor': '../addons/nkeditor/js/customplugin', 'nkeditor-core': '../addons/nkeditor/nkeditor.min', 'nkeditor-lang': '../addons/nkeditor/lang/zh-CN', }, shim: { 'nkeditor': { deps: [ 'nkeditor-core', 'nkeditor-lang' ] }, 'nkeditor-core': { deps: [ 'css!../addons/nkeditor/themes/black/editor.min.css', 'css!../addons/nkeditor/css/common.css' ], exports: 'window.KindEditor' }, 'nkeditor-lang': { deps: [ 'nkeditor-core' ] } } }); require(['form'], function (Form) { var _bindevent = Form.events.bindevent; Form.events.bindevent = function (form) { _bindevent.apply(this, [form]); if ($(".editor", form).size() > 0) { require(['nkeditor', 'upload'], function (Nkeditor, Upload) { var getImageFromClipboard, getImageFromDrop, getFileFromBase64; getImageFromClipboard = function (data) { var i, item; i = 0; while (i < data.clipboardData.items.length) { item = data.clipboardData.items[i]; if (item.type.indexOf("image") !== -1) { return item.getAsFile() || false; } i++; } return false; }; getImageFromDrop = function (data) { var i, item, images; i = 0; images = []; while (i < data.dataTransfer.files.length) { item = data.dataTransfer.files[i]; if (item.type.indexOf("image") !== -1) { images.push(item); } i++; } return images; }; getFileFromBase64 = function (data, url) { var arr = data.split(','), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n); while (n--) { u8arr[n] = bstr.charCodeAt(n); } var filename, suffix; if (typeof url != 'undefined') { var urlArr = url.split('.'); filename = url.substr(url.lastIndexOf('/') + 1); suffix = urlArr.pop(); } else { filename = Math.random().toString(36).substring(5, 15); } if (!suffix) { suffix = data.substring("data:image/".length, data.indexOf(";base64")); } var exp = new RegExp("\\." + suffix + "$", "i"); filename = exp.test(filename) ? filename : filename + "." + suffix; var file = new File([u8arr], filename, {type: mime}); return file; }; var getImageFromUrl = function (url, callback, outputFormat) { var canvas = document.createElement('CANVAS'), ctx = canvas.getContext('2d'), img = new Image; img.crossOrigin = 'Anonymous'; img.onload = function () { var urlArr = url.split('.'); var suffix = urlArr.pop(); suffix = suffix.match(/^(jpg|png|gif|bmp|jpeg)$/i) ? suffix : 'png'; try { canvas.height = img.height; canvas.width = img.width; ctx.drawImage(img, 0, 0); var dataURL = canvas.toDataURL(outputFormat || 'image/' + suffix); var file = getFileFromBase64(dataURL, url); } catch (e) { callback.call(this, null); } callback.call(this, file); canvas = null; }; img.onerror = function (e) { callback.call(this, null); }; img.src = Fast.api.fixurl("/addons/nkeditor/index/download") + "?url=" + encodeURIComponent(url); }; //上传Word图片 Nkeditor.uploadwordimage = function (index, image) { var that = this; (function () { var file = getFileFromBase64(image); var placeholder = new RegExp("##" + index + "##", "g"); Upload.api.send(file, function (data) { that.html(that.html().replace(placeholder, Fast.api.cdnurl(data.url))); }, function (data) { that.html(that.html().replace(placeholder, "")); }); }(index, image)); }; Nkeditor.lang({ remoteimage: '下载远程图片' }); //远程下载图片 Nkeditor.plugin('remoteimage', function (K) { var editor = this, name = 'remoteimage'; editor.plugin.remoteimage = { download: function (e) { var that = this; var html = that.html(); var staging = {}, orgined = {}, index = 0, images = 0, completed = 0, failured = 0; var checkrestore = function () { if (completed + failured >= images) { $.each(staging, function (i, j) { that.html(that.html().replace("" + i + "", j)); }); } }; html.replace(/([\s\S]*?)<\/code>/g, function (code) { staging[index] = code; return "" + index + ""; } ); html = html.replace(//g, function () { images++; var url = arguments[3]; var placeholder = ''; //如果是云存储的链接,则忽略 if (Config.upload.cdnurl && url.indexOf(Config.upload.cdnurl) > -1) { completed++; return arguments[0]; } else { orgined[index] = arguments[0]; } //下载远程图片 (function (index, url, placeholder) { getImageFromUrl(url, function (file) { if (!file) { failured++; that.html(that.html().replace(placeholder, orgined[index])); checkrestore(); } else { Upload.api.send(file, function (data) { completed++; that.html(that.html().replace(placeholder, '')); checkrestore(); }, function (data) { failured++; that.html(that.html().replace(placeholder, orgined[index])); checkrestore(); }); } }); })(index, url, placeholder); index++; return placeholder; }); if (index > 0) { that.html(html); } else { Toastr.info("没有需要下载的远程图片"); } } }; // 点击图标时执行 editor.clickToolbar(name, editor.plugin.remoteimage.download); }); $(".editor", form).each(function () { var that = this; Nkeditor.create(that, { width: '100%', filterMode: false, wellFormatMode: false, allowMediaUpload: true, //是否允许媒体上传 allowFileManager: true, allowImageUpload: true, fontSizeTable: ['9px', '10px', '12px', '14px', '16px', '18px', '21px', '24px', '32px'], wordImageServer: typeof Config.nkeditor != 'undefined' && Config.nkeditor.wordimageserver ? "127.0.0.1:10101" : "", //word图片替换服务器的IP和端口 urlType: Config.upload.cdnurl ? 'domain' : '',//给图片加前缀 cssPath: Fast.api.cdnurl('/assets/addons/nkeditor/plugins/code/prism.css'), cssData: "body {font-size: 13px}", fillDescAfterUploadImage: false, //是否在上传后继续添加描述信息 themeType: typeof Config.nkeditor != 'undefined' ? Config.nkeditor.theme : 'black', //编辑器皮肤,这个值从后台获取 fileManagerJson: Fast.api.fixurl("/addons/nkeditor/index/attachment/module/" + Config.modulename), items: [ 'source', 'undo', 'redo', 'preview', 'print', 'template', 'code', 'quote', 'cut', 'copy', 'paste', 'plainpaste', 'wordpaste', 'justifyleft', 'justifycenter', 'justifyright', 'justifyfull', 'insertorderedlist', 'insertunorderedlist', 'indent', 'outdent', 'subscript', 'superscript', 'clearhtml', 'quickformat', 'selectall', 'formatblock', 'fontname', 'fontsize', 'forecolor', 'hilitecolor', 'bold', 'italic', 'underline', 'strikethrough', 'lineheight', 'removeformat', 'image', 'multiimage', 'graft', 'flash', 'media', 'insertfile', 'table', 'hr', 'emoticons', 'baidumap', 'pagebreak', 'anchor', 'link', 'unlink', 'remoteimage', 'about', 'fullscreen' ], afterCreate: function () { var self = this; //Ctrl+回车提交 Nkeditor.ctrl(document, 13, function () { self.sync(); $(that).closest("form").submit(); }); Nkeditor.ctrl(self.edit.doc, 13, function () { self.sync(); $(that).closest("form").submit(); }); //粘贴上传 $("body", self.edit.doc).bind('paste', function (event) { var image, pasteEvent; pasteEvent = event.originalEvent; if (pasteEvent.clipboardData && pasteEvent.clipboardData.items) { image = getImageFromClipboard(pasteEvent); if (image) { event.preventDefault(); Upload.api.send(image, function (data) { self.exec("insertimage", Fast.api.cdnurl(data.url)); }); } } }); //挺拽上传 $("body", self.edit.doc).bind('drop', function (event) { var image, pasteEvent; pasteEvent = event.originalEvent; if (pasteEvent.dataTransfer && pasteEvent.dataTransfer.files) { images = getImageFromDrop(pasteEvent); if (images.length > 0) { event.preventDefault(); $.each(images, function (i, image) { Upload.api.send(image, function (data) { self.exec("insertimage", Fast.api.cdnurl(data.url)); }); }); } } }); }, //FastAdmin自定义处理 beforeUpload: function (callback, file) { var file = file ? file : $("input.ke-upload-file", this.form).prop('files')[0]; Upload.api.send(file, function (data) { var data = {code: '000', data: {url: Fast.api.cdnurl(data.url)}, title: '', width: '', height: '', border: '', align: ''}; callback(data); }); }, //错误处理 handler errorMsgHandler: function (message, type) { try { console.log(message, type); } catch (Error) { alert(message); } } }); }); }); } } }); });