ueditor-plus-assets 0.1.0 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (239) hide show
  1. package/README.md +3 -3
  2. package/dist/UEditorPlus/dialogs/ai/ai.html +139 -0
  3. package/dist/UEditorPlus/dialogs/ai/ai.js +282 -0
  4. package/dist/UEditorPlus/dialogs/anchor/anchor.html +62 -0
  5. package/dist/UEditorPlus/dialogs/attachment/attachment.css +716 -0
  6. package/dist/UEditorPlus/dialogs/attachment/attachment.html +61 -0
  7. package/dist/UEditorPlus/dialogs/attachment/attachment.js +797 -0
  8. package/dist/UEditorPlus/dialogs/attachment/images/alignicon.gif +0 -0
  9. package/dist/UEditorPlus/dialogs/attachment/images/alignicon.png +0 -0
  10. package/dist/UEditorPlus/dialogs/attachment/images/bg.png +0 -0
  11. package/dist/UEditorPlus/dialogs/attachment/images/file-icons.gif +0 -0
  12. package/dist/UEditorPlus/dialogs/attachment/images/file-icons.png +0 -0
  13. package/dist/UEditorPlus/dialogs/attachment/images/icons.gif +0 -0
  14. package/dist/UEditorPlus/dialogs/attachment/images/icons.png +0 -0
  15. package/dist/UEditorPlus/dialogs/attachment/images/image.png +0 -0
  16. package/dist/UEditorPlus/dialogs/attachment/images/progress.png +0 -0
  17. package/dist/UEditorPlus/dialogs/attachment/images/success.gif +0 -0
  18. package/dist/UEditorPlus/dialogs/attachment/images/success.png +0 -0
  19. package/dist/UEditorPlus/dialogs/audio/audio.css +818 -0
  20. package/dist/UEditorPlus/dialogs/audio/audio.html +83 -0
  21. package/dist/UEditorPlus/dialogs/audio/audio.js +805 -0
  22. package/dist/UEditorPlus/dialogs/audio/images/bg.png +0 -0
  23. package/dist/UEditorPlus/dialogs/audio/images/center_focus.jpg +0 -0
  24. package/dist/UEditorPlus/dialogs/audio/images/file-icons.gif +0 -0
  25. package/dist/UEditorPlus/dialogs/audio/images/file-icons.png +0 -0
  26. package/dist/UEditorPlus/dialogs/audio/images/icons.gif +0 -0
  27. package/dist/UEditorPlus/dialogs/audio/images/icons.png +0 -0
  28. package/dist/UEditorPlus/dialogs/audio/images/image.png +0 -0
  29. package/dist/UEditorPlus/dialogs/audio/images/left_focus.jpg +0 -0
  30. package/dist/UEditorPlus/dialogs/audio/images/none_focus.jpg +0 -0
  31. package/dist/UEditorPlus/dialogs/audio/images/progress.png +0 -0
  32. package/dist/UEditorPlus/dialogs/audio/images/right_focus.jpg +0 -0
  33. package/dist/UEditorPlus/dialogs/audio/images/success.gif +0 -0
  34. package/dist/UEditorPlus/dialogs/audio/images/success.png +0 -0
  35. package/dist/UEditorPlus/dialogs/background/background.css +193 -0
  36. package/dist/UEditorPlus/dialogs/background/background.html +59 -0
  37. package/dist/UEditorPlus/dialogs/background/background.js +370 -0
  38. package/dist/UEditorPlus/dialogs/background/images/bg.png +0 -0
  39. package/dist/UEditorPlus/dialogs/background/images/success.png +0 -0
  40. package/dist/UEditorPlus/dialogs/contentimport/contentimport.html +177 -0
  41. package/dist/UEditorPlus/dialogs/contentimport/contentimport.js +91 -0
  42. package/dist/UEditorPlus/dialogs/contentimport/mammoth.browser.min.js +21 -0
  43. package/dist/UEditorPlus/dialogs/contentimport/showdown.min.js +3 -0
  44. package/dist/UEditorPlus/dialogs/emotion/emotion.css +129 -0
  45. package/dist/UEditorPlus/dialogs/emotion/emotion.html +70 -0
  46. package/dist/UEditorPlus/dialogs/emotion/emotion.js +186 -0
  47. package/dist/UEditorPlus/dialogs/emotion/images/0.gif +0 -0
  48. package/dist/UEditorPlus/dialogs/emotion/images/bface.gif +0 -0
  49. package/dist/UEditorPlus/dialogs/emotion/images/cface.gif +0 -0
  50. package/dist/UEditorPlus/dialogs/emotion/images/fface.gif +0 -0
  51. package/dist/UEditorPlus/dialogs/emotion/images/jxface2.gif +0 -0
  52. package/dist/UEditorPlus/dialogs/emotion/images/neweditor-tab-bg.png +0 -0
  53. package/dist/UEditorPlus/dialogs/emotion/images/tface.gif +0 -0
  54. package/dist/UEditorPlus/dialogs/emotion/images/wface.gif +0 -0
  55. package/dist/UEditorPlus/dialogs/emotion/images/yface.gif +0 -0
  56. package/dist/UEditorPlus/dialogs/formula/formula.html +98 -0
  57. package/dist/UEditorPlus/dialogs/formula/formula.js +147 -0
  58. package/dist/UEditorPlus/dialogs/help/help.css +37 -0
  59. package/dist/UEditorPlus/dialogs/help/help.html +82 -0
  60. package/dist/UEditorPlus/dialogs/help/help.js +57 -0
  61. package/dist/UEditorPlus/dialogs/image/image.css +752 -0
  62. package/dist/UEditorPlus/dialogs/image/image.html +125 -0
  63. package/dist/UEditorPlus/dialogs/image/image.js +1051 -0
  64. package/dist/UEditorPlus/dialogs/image/images/alignicon.jpg +0 -0
  65. package/dist/UEditorPlus/dialogs/image/images/bg.png +0 -0
  66. package/dist/UEditorPlus/dialogs/image/images/icons.gif +0 -0
  67. package/dist/UEditorPlus/dialogs/image/images/icons.png +0 -0
  68. package/dist/UEditorPlus/dialogs/image/images/image.png +0 -0
  69. package/dist/UEditorPlus/dialogs/image/images/progress.png +0 -0
  70. package/dist/UEditorPlus/dialogs/image/images/success.gif +0 -0
  71. package/dist/UEditorPlus/dialogs/image/images/success.png +0 -0
  72. package/dist/UEditorPlus/dialogs/insertframe/insertframe.html +135 -0
  73. package/dist/UEditorPlus/dialogs/internal.js +81 -0
  74. package/dist/UEditorPlus/dialogs/link/link.html +155 -0
  75. package/dist/UEditorPlus/dialogs/preview/preview.html +45 -0
  76. package/dist/UEditorPlus/dialogs/scrawl/images/addimg.png +0 -0
  77. package/dist/UEditorPlus/dialogs/scrawl/images/brush.png +0 -0
  78. package/dist/UEditorPlus/dialogs/scrawl/images/delimg.png +0 -0
  79. package/dist/UEditorPlus/dialogs/scrawl/images/delimgH.png +0 -0
  80. package/dist/UEditorPlus/dialogs/scrawl/images/empty.png +0 -0
  81. package/dist/UEditorPlus/dialogs/scrawl/images/emptyH.png +0 -0
  82. package/dist/UEditorPlus/dialogs/scrawl/images/eraser.png +0 -0
  83. package/dist/UEditorPlus/dialogs/scrawl/images/redo.png +0 -0
  84. package/dist/UEditorPlus/dialogs/scrawl/images/redoH.png +0 -0
  85. package/dist/UEditorPlus/dialogs/scrawl/images/scale.png +0 -0
  86. package/dist/UEditorPlus/dialogs/scrawl/images/scaleH.png +0 -0
  87. package/dist/UEditorPlus/dialogs/scrawl/images/size.png +0 -0
  88. package/dist/UEditorPlus/dialogs/scrawl/images/undo.png +0 -0
  89. package/dist/UEditorPlus/dialogs/scrawl/images/undoH.png +0 -0
  90. package/dist/UEditorPlus/dialogs/scrawl/scrawl.css +324 -0
  91. package/dist/UEditorPlus/dialogs/scrawl/scrawl.html +95 -0
  92. package/dist/UEditorPlus/dialogs/scrawl/scrawl.js +707 -0
  93. package/dist/UEditorPlus/dialogs/searchreplace/searchreplace.html +144 -0
  94. package/dist/UEditorPlus/dialogs/searchreplace/searchreplace.js +174 -0
  95. package/dist/UEditorPlus/dialogs/spechars/spechars.html +42 -0
  96. package/dist/UEditorPlus/dialogs/spechars/spechars.js +86 -0
  97. package/dist/UEditorPlus/dialogs/table/dragicon.png +0 -0
  98. package/dist/UEditorPlus/dialogs/table/edittable.css +85 -0
  99. package/dist/UEditorPlus/dialogs/table/edittable.html +69 -0
  100. package/dist/UEditorPlus/dialogs/table/edittable.js +241 -0
  101. package/dist/UEditorPlus/dialogs/table/edittd.html +62 -0
  102. package/dist/UEditorPlus/dialogs/table/edittip.html +33 -0
  103. package/dist/UEditorPlus/dialogs/template/config.js +42 -0
  104. package/dist/UEditorPlus/dialogs/template/images/bg.gif +0 -0
  105. package/dist/UEditorPlus/dialogs/template/images/pre0.png +0 -0
  106. package/dist/UEditorPlus/dialogs/template/images/pre1.png +0 -0
  107. package/dist/UEditorPlus/dialogs/template/images/pre2.png +0 -0
  108. package/dist/UEditorPlus/dialogs/template/images/pre3.png +0 -0
  109. package/dist/UEditorPlus/dialogs/template/images/pre4.png +0 -0
  110. package/dist/UEditorPlus/dialogs/template/template.css +99 -0
  111. package/dist/UEditorPlus/dialogs/template/template.html +26 -0
  112. package/dist/UEditorPlus/dialogs/template/template.js +53 -0
  113. package/dist/UEditorPlus/dialogs/video/images/bg.png +0 -0
  114. package/dist/UEditorPlus/dialogs/video/images/center_focus.jpg +0 -0
  115. package/dist/UEditorPlus/dialogs/video/images/file-icons.gif +0 -0
  116. package/dist/UEditorPlus/dialogs/video/images/file-icons.png +0 -0
  117. package/dist/UEditorPlus/dialogs/video/images/icons.gif +0 -0
  118. package/dist/UEditorPlus/dialogs/video/images/icons.png +0 -0
  119. package/dist/UEditorPlus/dialogs/video/images/image.png +0 -0
  120. package/dist/UEditorPlus/dialogs/video/images/left_focus.jpg +0 -0
  121. package/dist/UEditorPlus/dialogs/video/images/none_focus.jpg +0 -0
  122. package/dist/UEditorPlus/dialogs/video/images/progress.png +0 -0
  123. package/dist/UEditorPlus/dialogs/video/images/right_focus.jpg +0 -0
  124. package/dist/UEditorPlus/dialogs/video/images/success.gif +0 -0
  125. package/dist/UEditorPlus/dialogs/video/images/success.png +0 -0
  126. package/dist/UEditorPlus/dialogs/video/video.css +818 -0
  127. package/dist/UEditorPlus/dialogs/video/video.html +109 -0
  128. package/dist/UEditorPlus/dialogs/video/video.js +910 -0
  129. package/dist/UEditorPlus/dialogs/wordimage/wordimage.html +222 -0
  130. package/dist/UEditorPlus/dialogs/wordimage/wordimage.js +93 -0
  131. package/dist/UEditorPlus/index.html +168 -0
  132. package/dist/UEditorPlus/lang/en/en.js +788 -0
  133. package/dist/UEditorPlus/lang/en/images/addimage.png +0 -0
  134. package/dist/UEditorPlus/lang/en/images/alldeletebtnhoverskin.png +0 -0
  135. package/dist/UEditorPlus/lang/en/images/alldeletebtnupskin.png +0 -0
  136. package/dist/UEditorPlus/lang/en/images/background.png +0 -0
  137. package/dist/UEditorPlus/lang/en/images/button.png +0 -0
  138. package/dist/UEditorPlus/lang/en/images/copy.png +0 -0
  139. package/dist/UEditorPlus/lang/en/images/deletedisable.png +0 -0
  140. package/dist/UEditorPlus/lang/en/images/deleteenable.png +0 -0
  141. package/dist/UEditorPlus/lang/en/images/listbackground.png +0 -0
  142. package/dist/UEditorPlus/lang/en/images/localimage.png +0 -0
  143. package/dist/UEditorPlus/lang/en/images/music.png +0 -0
  144. package/dist/UEditorPlus/lang/en/images/rotateleftdisable.png +0 -0
  145. package/dist/UEditorPlus/lang/en/images/rotateleftenable.png +0 -0
  146. package/dist/UEditorPlus/lang/en/images/rotaterightdisable.png +0 -0
  147. package/dist/UEditorPlus/lang/en/images/rotaterightenable.png +0 -0
  148. package/dist/UEditorPlus/lang/en/images/upload.png +0 -0
  149. package/dist/UEditorPlus/lang/zh-cn/images/copy.png +0 -0
  150. package/dist/UEditorPlus/lang/zh-cn/images/localimage.png +0 -0
  151. package/dist/UEditorPlus/lang/zh-cn/images/music.png +0 -0
  152. package/dist/UEditorPlus/lang/zh-cn/images/upload.png +0 -0
  153. package/dist/UEditorPlus/lang/zh-cn/zh-cn.js +812 -0
  154. package/dist/UEditorPlus/plugins/demo/demo.js +3 -0
  155. package/dist/UEditorPlus/themes/default/css/ueditor.css +2170 -0
  156. package/dist/UEditorPlus/themes/default/dialog.css +642 -0
  157. package/dist/UEditorPlus/themes/default/dialogbase.css +100 -0
  158. package/dist/UEditorPlus/themes/default/exts/ai.svg +12 -0
  159. package/dist/UEditorPlus/themes/default/exts/apk.svg +12 -0
  160. package/dist/UEditorPlus/themes/default/exts/chm.svg +12 -0
  161. package/dist/UEditorPlus/themes/default/exts/css.svg +12 -0
  162. package/dist/UEditorPlus/themes/default/exts/doc.svg +22 -0
  163. package/dist/UEditorPlus/themes/default/exts/docx.svg +22 -0
  164. package/dist/UEditorPlus/themes/default/exts/dwg.svg +16 -0
  165. package/dist/UEditorPlus/themes/default/exts/folder.svg +3 -0
  166. package/dist/UEditorPlus/themes/default/exts/gif.svg +14 -0
  167. package/dist/UEditorPlus/themes/default/exts/html.svg +12 -0
  168. package/dist/UEditorPlus/themes/default/exts/jpeg.svg +14 -0
  169. package/dist/UEditorPlus/themes/default/exts/jpg.svg +14 -0
  170. package/dist/UEditorPlus/themes/default/exts/log.svg +12 -0
  171. package/dist/UEditorPlus/themes/default/exts/mp3.svg +14 -0
  172. package/dist/UEditorPlus/themes/default/exts/mp4.svg +12 -0
  173. package/dist/UEditorPlus/themes/default/exts/pdf.svg +14 -0
  174. package/dist/UEditorPlus/themes/default/exts/png.svg +14 -0
  175. package/dist/UEditorPlus/themes/default/exts/ppt.svg +24 -0
  176. package/dist/UEditorPlus/themes/default/exts/pptx.svg +24 -0
  177. package/dist/UEditorPlus/themes/default/exts/psd.svg +12 -0
  178. package/dist/UEditorPlus/themes/default/exts/rar.svg +12 -0
  179. package/dist/UEditorPlus/themes/default/exts/svg.svg +12 -0
  180. package/dist/UEditorPlus/themes/default/exts/torrent.svg +14 -0
  181. package/dist/UEditorPlus/themes/default/exts/txt.svg +14 -0
  182. package/dist/UEditorPlus/themes/default/exts/unknown.svg +12 -0
  183. package/dist/UEditorPlus/themes/default/exts/xls.svg +25 -0
  184. package/dist/UEditorPlus/themes/default/exts/xlsx.svg +25 -0
  185. package/dist/UEditorPlus/themes/default/exts/zip.svg +12 -0
  186. package/dist/UEditorPlus/themes/default/images/anchor.gif +0 -0
  187. package/dist/UEditorPlus/themes/default/images/arrow.png +0 -0
  188. package/dist/UEditorPlus/themes/default/images/arrow_down.png +0 -0
  189. package/dist/UEditorPlus/themes/default/images/arrow_up.png +0 -0
  190. package/dist/UEditorPlus/themes/default/images/button-bg.gif +0 -0
  191. package/dist/UEditorPlus/themes/default/images/cancelbutton.gif +0 -0
  192. package/dist/UEditorPlus/themes/default/images/charts.png +0 -0
  193. package/dist/UEditorPlus/themes/default/images/cursor_h.gif +0 -0
  194. package/dist/UEditorPlus/themes/default/images/cursor_h.png +0 -0
  195. package/dist/UEditorPlus/themes/default/images/cursor_v.gif +0 -0
  196. package/dist/UEditorPlus/themes/default/images/cursor_v.png +0 -0
  197. package/dist/UEditorPlus/themes/default/images/dialog-title-bg.png +0 -0
  198. package/dist/UEditorPlus/themes/default/images/filescan.png +0 -0
  199. package/dist/UEditorPlus/themes/default/images/highlighted.gif +0 -0
  200. package/dist/UEditorPlus/themes/default/images/icons-all.gif +0 -0
  201. package/dist/UEditorPlus/themes/default/images/icons.gif +0 -0
  202. package/dist/UEditorPlus/themes/default/images/icons.png +0 -0
  203. package/dist/UEditorPlus/themes/default/images/img-cracked.png +0 -0
  204. package/dist/UEditorPlus/themes/default/images/loaderror.png +0 -0
  205. package/dist/UEditorPlus/themes/default/images/loading.gif +0 -0
  206. package/dist/UEditorPlus/themes/default/images/lock.gif +0 -0
  207. package/dist/UEditorPlus/themes/default/images/neweditor-tab-bg.png +0 -0
  208. package/dist/UEditorPlus/themes/default/images/pagebreak.gif +0 -0
  209. package/dist/UEditorPlus/themes/default/images/scale.png +0 -0
  210. package/dist/UEditorPlus/themes/default/images/sortable.png +0 -0
  211. package/dist/UEditorPlus/themes/default/images/spacer.gif +0 -0
  212. package/dist/UEditorPlus/themes/default/images/sparator_v.png +0 -0
  213. package/dist/UEditorPlus/themes/default/images/table-cell-align.png +0 -0
  214. package/dist/UEditorPlus/themes/default/images/tangram-colorpicker.png +0 -0
  215. package/dist/UEditorPlus/themes/default/images/toolbar_bg.png +0 -0
  216. package/dist/UEditorPlus/themes/default/images/unhighlighted.gif +0 -0
  217. package/dist/UEditorPlus/themes/default/images/upload.png +0 -0
  218. package/dist/UEditorPlus/themes/default/images/videologo.gif +0 -0
  219. package/dist/UEditorPlus/themes/default/images/word.gif +0 -0
  220. package/dist/UEditorPlus/themes/default/images/wordpaste.png +0 -0
  221. package/dist/UEditorPlus/themes/iframe.css +63 -0
  222. package/dist/UEditorPlus/third-party/SyntaxHighlighter/shCore.js +3655 -0
  223. package/dist/UEditorPlus/third-party/SyntaxHighlighter/shCoreDefault.css +1 -0
  224. package/dist/UEditorPlus/third-party/clipboard/clipboard.js +753 -0
  225. package/dist/UEditorPlus/third-party/clipboard/clipboard.swf +0 -0
  226. package/dist/UEditorPlus/third-party/codemirror/codemirror.css +106 -0
  227. package/dist/UEditorPlus/third-party/codemirror/codemirror.js +3581 -0
  228. package/dist/UEditorPlus/third-party/jquery-1.10.2.js +6 -0
  229. package/dist/UEditorPlus/third-party/showdown.js +2 -0
  230. package/dist/UEditorPlus/third-party/vue.js +1 -0
  231. package/dist/UEditorPlus/third-party/webuploader/webuploader.css +88 -0
  232. package/dist/UEditorPlus/third-party/webuploader/webuploader.js +10178 -0
  233. package/dist/UEditorPlus/third-party/zeroclipboard/ZeroClipboard.js +1256 -0
  234. package/dist/UEditorPlus/third-party/zeroclipboard/ZeroClipboard.swf +0 -0
  235. package/dist/UEditorPlus/ueditor.all.js +36896 -0
  236. package/dist/UEditorPlus/ueditor.config.js +761 -0
  237. package/dist/UEditorPlus/ueditor.parse.js +907 -0
  238. package/index.js +5 -5
  239. package/package.json +29 -29
@@ -0,0 +1,1051 @@
1
+ /**
2
+ * User: Jinqn
3
+ * Date: 14-04-08
4
+ * Time: 下午16:34
5
+ * 上传图片对话框逻辑代码,包括tab: 远程图片/上传图片/在线图片/搜索图片
6
+ */
7
+ (function () {
8
+
9
+ var remoteImage,
10
+ uploadImage,
11
+ onlineImage;
12
+ var editorOpt = {};
13
+
14
+ window.onload = function () {
15
+ editorOpt = editor.getOpt('imageConfig');
16
+ initTabs();
17
+ initAlign();
18
+ initButtons();
19
+ };
20
+
21
+ /* 初始化tab标签 */
22
+ function initTabs() {
23
+ var tabs = $G('tabhead').children;
24
+ for (var i = 0; i < tabs.length; i++) {
25
+ domUtils.on(tabs[i], "click", function (e) {
26
+ var target = e.target || e.srcElement;
27
+ setTabFocus(target.getAttribute('data-content-id'));
28
+ });
29
+ }
30
+ if (!editorOpt.disableUpload) {
31
+ $G('tabhead').querySelector('[data-content-id="upload"]').style.display = 'inline-block';
32
+ }
33
+ if (!editorOpt.disableOnline) {
34
+ $G('tabhead').querySelector('[data-content-id="online"]').style.display = 'inline-block';
35
+ }
36
+ if (!!editorOpt.selectCallback) {
37
+ $G('imageSelect').style.display = 'inline-block';
38
+ domUtils.on($G('imageSelect'), "click", function (e) {
39
+ editorOpt.selectCallback(editor, function (info) {
40
+ if (info) {
41
+ $G('url').value = info.path;
42
+ $G('title').value = info.name;
43
+ var img = new Image();
44
+ img.onload = function () {
45
+ $G('width').value = img.width;
46
+ $G('height').value = img.height;
47
+ remoteImage.setPreview();
48
+ };
49
+ img.onerror = function () {
50
+ remoteImage.setPreview();
51
+ };
52
+ img.src = info.path;
53
+ }
54
+ });
55
+ });
56
+ }
57
+ var img = editor.selection.getRange().getClosedNode();
58
+ if (img && img.tagName && img.tagName.toLowerCase() == 'img') {
59
+ setTabFocus('remote');
60
+ } else {
61
+ setTabFocus('remote');
62
+ }
63
+ }
64
+
65
+ /* 初始化tabbody */
66
+ function setTabFocus(id) {
67
+ if (!id) return;
68
+ var i, bodyId, tabs = $G('tabhead').children;
69
+ for (i = 0; i < tabs.length; i++) {
70
+ bodyId = tabs[i].getAttribute('data-content-id');
71
+ if (bodyId == id) {
72
+ domUtils.addClass(tabs[i], 'focus');
73
+ domUtils.addClass($G(bodyId), 'focus');
74
+ } else {
75
+ domUtils.removeClasses(tabs[i], 'focus');
76
+ domUtils.removeClasses($G(bodyId), 'focus');
77
+ }
78
+ }
79
+ switch (id) {
80
+ case 'remote':
81
+ remoteImage = remoteImage || new RemoteImage();
82
+ break;
83
+ case 'upload':
84
+ setAlign(editor.getOpt('imageInsertAlign'));
85
+ uploadImage = uploadImage || new UploadImage('queueList');
86
+ break;
87
+ case 'online':
88
+ setAlign(editor.getOpt('imageManagerInsertAlign'));
89
+ onlineImage = onlineImage || new OnlineImage('imageList');
90
+ onlineImage.reset();
91
+ break;
92
+ }
93
+ }
94
+
95
+ /* 初始化onok事件 */
96
+ function initButtons() {
97
+
98
+ dialog.onok = function () {
99
+ var remote = false, list = [], id, tabs = $G('tabhead').children;
100
+ for (var i = 0; i < tabs.length; i++) {
101
+ if (domUtils.hasClass(tabs[i], 'focus')) {
102
+ id = tabs[i].getAttribute('data-content-id');
103
+ break;
104
+ }
105
+ }
106
+
107
+ switch (id) {
108
+ case 'remote':
109
+ list = remoteImage.getInsertList();
110
+ break;
111
+ case 'upload':
112
+ list = uploadImage.getInsertList();
113
+ var count = uploadImage.getQueueCount();
114
+ if (count) {
115
+ $('.info', '#queueList').html('<span style="color:red;">' + '还有2个未上传文件'.replace(/[\d]/, count) + '</span>');
116
+ return false;
117
+ }
118
+ break;
119
+ case 'online':
120
+ list = onlineImage.getInsertList();
121
+ break;
122
+ }
123
+
124
+ if (list) {
125
+ editor.execCommand('insertimage', list);
126
+ remote && editor.fireEvent("catchRemoteImage");
127
+ }
128
+ };
129
+ }
130
+
131
+
132
+ /* 初始化对其方式的点击事件 */
133
+ function initAlign() {
134
+ /* 点击align图标 */
135
+ domUtils.on($G("alignIcon"), 'click', function (e) {
136
+ var target = e.target || e.srcElement;
137
+ if (target.className && target.className.indexOf('-align') != -1) {
138
+ setAlign(target.getAttribute('data-align'));
139
+ }
140
+ });
141
+ }
142
+
143
+ /* 设置对齐方式 */
144
+ function setAlign(align) {
145
+ align = align || 'none';
146
+ var aligns = $G("alignIcon").children;
147
+ for (i = 0; i < aligns.length; i++) {
148
+ if (aligns[i].getAttribute('data-align') == align) {
149
+ domUtils.addClass(aligns[i], 'focus');
150
+ $G("align").value = aligns[i].getAttribute('data-align');
151
+ } else {
152
+ domUtils.removeClasses(aligns[i], 'focus');
153
+ }
154
+ }
155
+ }
156
+
157
+ /* 获取对齐方式 */
158
+ function getAlign() {
159
+ var align = $G("align").value || 'none';
160
+ return align == 'none' ? '' : align;
161
+ }
162
+
163
+
164
+ /* 在线图片 */
165
+ function RemoteImage(target) {
166
+ this.container = utils.isString(target) ? document.getElementById(target) : target;
167
+ this.init();
168
+ }
169
+
170
+ RemoteImage.prototype = {
171
+ init: function () {
172
+ this.initContainer();
173
+ this.initEvents();
174
+ },
175
+ initContainer: function () {
176
+ this.dom = {
177
+ 'url': $G('url'),
178
+ 'width': $G('width'),
179
+ 'height': $G('height'),
180
+ 'border': $G('border'),
181
+ 'vhSpace': $G('vhSpace'),
182
+ 'title': $G('title'),
183
+ 'align': $G('align')
184
+ };
185
+ var img = editor.selection.getRange().getClosedNode();
186
+ if (img) {
187
+ this.setImage(img);
188
+ }
189
+ },
190
+ initEvents: function () {
191
+ var _this = this,
192
+ locker = $G('lock');
193
+
194
+ /* 改变url */
195
+ domUtils.on($G("url"), 'keyup', updatePreview);
196
+ domUtils.on($G("border"), 'keyup', updatePreview);
197
+ domUtils.on($G("title"), 'keyup', updatePreview);
198
+
199
+ domUtils.on($G("width"), 'keyup', function () {
200
+ if (locker.checked) {
201
+ var proportion = locker.getAttribute('data-proportion');
202
+ $G('height').value = Math.round(this.value / proportion);
203
+ } else {
204
+ _this.updateLocker();
205
+ }
206
+ updatePreview();
207
+ });
208
+ domUtils.on($G("height"), 'keyup', function () {
209
+ if (locker.checked) {
210
+ var proportion = locker.getAttribute('data-proportion');
211
+ $G('width').value = Math.round(this.value * proportion);
212
+ } else {
213
+ _this.updateLocker();
214
+ }
215
+ updatePreview();
216
+ });
217
+ domUtils.on($G("lock"), 'change', function () {
218
+ var proportion = parseInt($G("width").value) / parseInt($G("height").value);
219
+ locker.setAttribute('data-proportion', proportion);
220
+ });
221
+
222
+ function updatePreview() {
223
+ _this.setPreview();
224
+ }
225
+ },
226
+ updateLocker: function () {
227
+ var width = $G('width').value,
228
+ height = $G('height').value,
229
+ locker = $G('lock');
230
+ if (width && height && width == parseInt(width) && height == parseInt(height)) {
231
+ locker.disabled = false;
232
+ locker.title = '';
233
+ } else {
234
+ locker.checked = false;
235
+ locker.disabled = 'disabled';
236
+ locker.title = lang.remoteLockError;
237
+ }
238
+ },
239
+ setImage: function (img) {
240
+ /* 不是正常的图片 */
241
+ if (!img.tagName || img.tagName.toLowerCase() != 'img' && !img.getAttribute("src") || !img.src) return;
242
+
243
+ var wordImgFlag = img.getAttribute("data-word-image"),
244
+ src = wordImgFlag ? wordImgFlag.replace("&amp;", "&") : (img.getAttribute('_src') || img.getAttribute("src", 2).replace("&amp;", "&")),
245
+ align = editor.queryCommandValue("imageFloat");
246
+
247
+ /* 防止onchange事件循环调用 */
248
+ if (src !== $G("url").value) $G("url").value = src;
249
+ if (src) {
250
+ /* 设置表单内容 */
251
+ $G("width").value = img.width || '';
252
+ $G("height").value = img.height || '';
253
+ $G("border").value = img.getAttribute("border") || '0';
254
+ $G("vhSpace").value = img.getAttribute("vspace") || '0';
255
+ $G("title").value = img.title || img.alt || '';
256
+ setAlign(align);
257
+ this.setPreview();
258
+ this.updateLocker();
259
+ }
260
+ },
261
+ getData: function () {
262
+ var data = {};
263
+ for (var k in this.dom) {
264
+ data[k] = this.dom[k].value;
265
+ }
266
+ return data;
267
+ },
268
+ setPreview: function () {
269
+ var url = $G('url').value,
270
+ ow = $G('width').value,
271
+ oh = $G('height').value,
272
+ border = $G('border').value,
273
+ title = $G('title').value,
274
+ preview = $G('preview'),
275
+ width,
276
+ height;
277
+
278
+ width = ((!ow || !oh) ? preview.offsetWidth : Math.min(ow, preview.offsetWidth));
279
+ width = width + (border * 2) > preview.offsetWidth ? width : (preview.offsetWidth - (border * 2));
280
+ height = (!ow || !oh) ? '' : width * oh / ow;
281
+
282
+ if (url) {
283
+ preview.innerHTML = '<img src="' + url + '" width="' + width + '" height="' + height + '" border="' + border + 'px solid #000" title="' + title + '" />';
284
+ }
285
+ },
286
+ getInsertList: function () {
287
+ var data = this.getData();
288
+ if (data['url']) {
289
+ var img = {
290
+ src: data['url'],
291
+ _src: data['url'],
292
+ }
293
+ img._propertyDelete = []
294
+ img.style = []
295
+ if (data['width']) {
296
+ img.width = data['width'];
297
+ img.style.push('width:' + data['width'] + 'px');
298
+ } else {
299
+ img._propertyDelete.push('width');
300
+ }
301
+ if (data['height']) {
302
+ img.height = data['height'];
303
+ img.style.push('height:' + data['height'] + 'px');
304
+ } else {
305
+ img._propertyDelete.push('height');
306
+ }
307
+ if (data['border']) {
308
+ img.border = data['border'];
309
+ } else {
310
+ img._propertyDelete.push('border');
311
+ }
312
+ if (data['align']) {
313
+ img.floatStyle = data['align'];
314
+ } else {
315
+ img._propertyDelete.push('floatStyle');
316
+ }
317
+ if (data['vhSpace']) {
318
+ img.vspace = data['vhSpace'];
319
+ } else {
320
+ img._propertyDelete.push('vspace');
321
+ }
322
+ if (data['title']) {
323
+ img.alt = data['title'];
324
+ } else {
325
+ img._propertyDelete.push('alt');
326
+ }
327
+ if (img.style.length > 0) {
328
+ img.style = img.style.join(';');
329
+ } else {
330
+ img._propertyDelete.push('style');
331
+ }
332
+ return [img];
333
+ } else {
334
+ return [];
335
+ }
336
+ }
337
+ };
338
+
339
+
340
+ /* 上传图片 */
341
+ function UploadImage(target) {
342
+ this.$wrap = target.constructor == String ? $('#' + target) : $(target);
343
+ this.init();
344
+ }
345
+
346
+ UploadImage.prototype = {
347
+ init: function () {
348
+ this.imageList = [];
349
+ this.initContainer();
350
+ this.initUploader();
351
+ },
352
+ initContainer: function () {
353
+ this.$queue = this.$wrap.find('.filelist');
354
+ },
355
+ /* 初始化容器 */
356
+ initUploader: function () {
357
+ var _this = this,
358
+ $ = jQuery, // just in case. Make sure it's not an other libaray.
359
+ $wrap = _this.$wrap,
360
+ // 图片容器
361
+ $queue = $wrap.find('.filelist'),
362
+ // 状态栏,包括进度和控制按钮
363
+ $statusBar = $wrap.find('.statusBar'),
364
+ // 文件总体选择信息。
365
+ $info = $statusBar.find('.info'),
366
+ // 上传按钮
367
+ $upload = $wrap.find('.uploadBtn'),
368
+ // 上传按钮
369
+ $filePickerBtn = $wrap.find('.filePickerBtn'),
370
+ // 上传按钮
371
+ $filePickerBlock = $wrap.find('.filePickerBlock'),
372
+ // 没选择文件之前的内容。
373
+ $placeHolder = $wrap.find('.placeholder'),
374
+ // 总体进度条
375
+ $progress = $statusBar.find('.progress').hide(),
376
+ // 添加的文件数量
377
+ fileCount = 0,
378
+ // 添加的文件总大小
379
+ fileSize = 0,
380
+ // 优化retina, 在retina下这个值是2
381
+ ratio = window.devicePixelRatio || 1,
382
+ // 缩略图大小
383
+ thumbnailWidth = 113 * ratio,
384
+ thumbnailHeight = 113 * ratio,
385
+ // 可能有pedding, ready, uploading, confirm, done.
386
+ state = '',
387
+ // 所有文件的进度信息,key为file id
388
+ percentages = {},
389
+ supportTransition = (function () {
390
+ var s = document.createElement('p').style,
391
+ r = 'transition' in s ||
392
+ 'WebkitTransition' in s ||
393
+ 'MozTransition' in s ||
394
+ 'msTransition' in s ||
395
+ 'OTransition' in s;
396
+ s = null;
397
+ return r;
398
+ })(),
399
+ // WebUploader实例
400
+ uploader,
401
+ actionUrl = editor.getActionUrl(editor.getOpt('imageActionName')),
402
+ acceptExtensions = (editor.getOpt('imageAllowFiles') || []).join('').replace(/\./g, ',').replace(/^[,]/, ''),
403
+ imageMaxSize = editor.getOpt('imageMaxSize'),
404
+ imageCompressBorder = editor.getOpt('imageCompressBorder');
405
+
406
+ if (!WebUploader.Uploader.support()) {
407
+ $('#filePickerReady').after($('<div>').html(lang.errorNotSupport)).hide();
408
+ return;
409
+ } else if (!editor.getOpt('imageActionName')) {
410
+ $('#filePickerReady').after($('<div>').html(lang.errorLoadConfig)).hide();
411
+ return;
412
+ }
413
+
414
+ var uploaderOption = {
415
+ pick: {
416
+ id: '#filePickerReady',
417
+ label: lang.uploadSelectFile
418
+ },
419
+ accept: {
420
+ title: 'Images',
421
+ extensions: acceptExtensions,
422
+ mimeTypes: 'image/*'
423
+ },
424
+ swf: '../../third-party/webuploader/Uploader.swf',
425
+ server: actionUrl,
426
+ fileVal: editor.getOpt('imageFieldName'),
427
+ duplicate: true,
428
+ fileSingleSizeLimit: imageMaxSize, // 默认 2 M
429
+ threads: 1,
430
+ headers: editor.getOpt('serverHeaders') || {},
431
+ compress: editor.getOpt('imageCompressEnable') ? {
432
+ enable: editor.getOpt('imageCompressEnable'),
433
+ maxWidthOrHeight: imageCompressBorder,
434
+ maxSize: imageMaxSize,
435
+ } : false
436
+ };
437
+ if(editor.getOpt('uploadServiceEnable')) {
438
+ uploaderOption.customUpload = function (file, callback) {
439
+ editor.getOpt('uploadServiceUpload')('image', file, {
440
+ success: function( res ) {
441
+ callback.onSuccess(file, {_raw:JSON.stringify(res)});
442
+ },
443
+ error: function( err ) {
444
+ callback.onError(file, err);
445
+ },
446
+ progress: function( percent ) {
447
+ callback.onProgress(file, percent);
448
+ }
449
+ }, {
450
+ from: 'image'
451
+ });
452
+ };
453
+ }
454
+
455
+ uploader = _this.uploader = WebUploader.create(uploaderOption);
456
+ uploader.addButton({
457
+ id: '#filePickerBlock'
458
+ });
459
+ uploader.addButton({
460
+ id: '#filePickerBtn',
461
+ label: lang.uploadAddFile
462
+ });
463
+
464
+ setState('pedding');
465
+
466
+ // 当有文件添加进来时执行,负责view的创建
467
+ function addFile(file) {
468
+ var $li = $('<li id="' + file.id + '">' +
469
+ '<p class="title">' + file.name + '</p>' +
470
+ '<p class="imgWrap"></p>' +
471
+ '<p class="progress"><span></span></p>' +
472
+ '</li>'),
473
+
474
+ $btns = $('<div class="file-panel">' +
475
+ '<span class="cancel">' + lang.uploadDelete + '</span>' +
476
+ '<span class="rotateRight">' + lang.uploadTurnRight + '</span>' +
477
+ '<span class="rotateLeft">' + lang.uploadTurnLeft + '</span></div>').appendTo($li),
478
+ $prgress = $li.find('p.progress span'),
479
+ $wrap = $li.find('p.imgWrap'),
480
+ $info = $('<p class="error"></p>').hide().appendTo($li),
481
+
482
+ showError = function (code) {
483
+ switch (code) {
484
+ case 'exceed_size':
485
+ text = lang.errorExceedSize;
486
+ break;
487
+ case 'interrupt':
488
+ text = lang.errorInterrupt;
489
+ break;
490
+ case 'http':
491
+ text = lang.errorHttp;
492
+ break;
493
+ case 'not_allow_type':
494
+ text = lang.errorFileType;
495
+ break;
496
+ default:
497
+ text = lang.errorUploadRetry;
498
+ break;
499
+ }
500
+ $info.text(text).show();
501
+ };
502
+
503
+ if (file.getStatus() === 'invalid') {
504
+ showError(file.statusText);
505
+ } else {
506
+ $wrap.text(lang.uploadPreview);
507
+ if (browser.ie && browser.version <= 7) {
508
+ $wrap.text(lang.uploadNoPreview);
509
+ } else {
510
+ uploader.makeThumb(file, function (error, src) {
511
+ if (error || !src) {
512
+ $wrap.text(lang.uploadNoPreview);
513
+ } else {
514
+ var $img = $('<img src="' + src + '">');
515
+ $wrap.empty().append($img);
516
+ $img.on('error', function () {
517
+ $wrap.text(lang.uploadNoPreview);
518
+ });
519
+ }
520
+ }, thumbnailWidth, thumbnailHeight);
521
+ }
522
+ percentages[file.id] = [file.size, 0];
523
+ file.rotation = 0;
524
+
525
+ /* 检查文件格式 */
526
+ if (!file.ext || acceptExtensions.indexOf(file.ext.toLowerCase()) == -1) {
527
+ showError('not_allow_type');
528
+ uploader.removeFile(file);
529
+ }
530
+ }
531
+
532
+ file.on('statuschange', function (cur, prev) {
533
+ if (prev === 'progress') {
534
+ $prgress.hide().width(0);
535
+ } else if (prev === 'queued') {
536
+ $li.off('mouseenter mouseleave');
537
+ $btns.remove();
538
+ }
539
+ // 成功
540
+ if (cur === 'error' || cur === 'invalid') {
541
+ showError(file.statusText);
542
+ percentages[file.id][1] = 1;
543
+ } else if (cur === 'interrupt') {
544
+ showError('interrupt');
545
+ } else if (cur === 'queued') {
546
+ percentages[file.id][1] = 0;
547
+ } else if (cur === 'progress') {
548
+ $info.hide();
549
+ $prgress.css('display', 'block');
550
+ } else if (cur === 'complete') {
551
+ }
552
+
553
+ $li.removeClass('state-' + prev).addClass('state-' + cur);
554
+ });
555
+
556
+ $li.on('mouseenter', function () {
557
+ $btns.stop().animate({height: 30});
558
+ });
559
+ $li.on('mouseleave', function () {
560
+ $btns.stop().animate({height: 0});
561
+ });
562
+
563
+ $btns.on('click', 'span', function () {
564
+ var index = $(this).index(),
565
+ deg;
566
+
567
+ switch (index) {
568
+ case 0:
569
+ uploader.removeFile(file);
570
+ return;
571
+ case 1:
572
+ file.rotation += 90;
573
+ break;
574
+ case 2:
575
+ file.rotation -= 90;
576
+ break;
577
+ }
578
+
579
+ if (supportTransition) {
580
+ deg = 'rotate(' + file.rotation + 'deg)';
581
+ $wrap.css({
582
+ '-webkit-transform': deg,
583
+ '-mos-transform': deg,
584
+ '-o-transform': deg,
585
+ 'transform': deg
586
+ });
587
+ } else {
588
+ $wrap.css('filter', 'progid:DXImageTransform.Microsoft.BasicImage(rotation=' + (~~((file.rotation / 90) % 4 + 4) % 4) + ')');
589
+ }
590
+
591
+ });
592
+
593
+ $li.insertBefore($filePickerBlock);
594
+ }
595
+
596
+ // 负责view的销毁
597
+ function removeFile(file) {
598
+ var $li = $('#' + file.id);
599
+ delete percentages[file.id];
600
+ updateTotalProgress();
601
+ $li.off().find('.file-panel').off().end().remove();
602
+ }
603
+
604
+ function updateTotalProgress() {
605
+ var loaded = 0,
606
+ total = 0,
607
+ spans = $progress.children(),
608
+ percent;
609
+
610
+ $.each(percentages, function (k, v) {
611
+ total += v[0];
612
+ loaded += v[0] * v[1];
613
+ });
614
+
615
+ percent = total ? loaded / total : 0;
616
+
617
+ spans.eq(0).text(Math.round(percent * 100) + '%');
618
+ spans.eq(1).css('width', Math.round(percent * 100) + '%');
619
+ updateStatus();
620
+ }
621
+
622
+ function setState(val, files) {
623
+
624
+ if (val !== state) {
625
+
626
+ var stats = uploader.getStats();
627
+
628
+ $upload.removeClass('state-' + state);
629
+ $upload.addClass('state-' + val);
630
+
631
+ switch (val) {
632
+
633
+ /* 未选择文件 */
634
+ case 'pedding':
635
+ $queue.addClass('element-invisible');
636
+ $statusBar.addClass('element-invisible');
637
+ $placeHolder.removeClass('element-invisible');
638
+ $progress.hide();
639
+ $info.hide();
640
+ uploader.refresh();
641
+ break;
642
+
643
+ /* 可以开始上传 */
644
+ case 'ready':
645
+ $placeHolder.addClass('element-invisible');
646
+ $queue.removeClass('element-invisible');
647
+ $statusBar.removeClass('element-invisible');
648
+ $progress.hide();
649
+ $info.show();
650
+ $upload.text(lang.uploadStart);
651
+ uploader.refresh();
652
+ break;
653
+
654
+ /* 上传中 */
655
+ case 'uploading':
656
+ $progress.show();
657
+ $info.hide();
658
+ $upload.text(lang.uploadPause);
659
+ break;
660
+
661
+ /* 暂停上传 */
662
+ case 'paused':
663
+ $progress.show();
664
+ $info.hide();
665
+ $upload.text(lang.uploadContinue);
666
+ break;
667
+
668
+ case 'confirm':
669
+ $progress.show();
670
+ $info.hide();
671
+ $upload.text(lang.uploadStart);
672
+
673
+ stats = uploader.getStats();
674
+ if (stats.successNum && !stats.uploadFailNum) {
675
+ setState('finish');
676
+ return;
677
+ }
678
+ break;
679
+
680
+ case 'finish':
681
+ $progress.hide();
682
+ $info.show();
683
+ if (stats.uploadFailNum) {
684
+ $upload.text(lang.uploadRetry);
685
+ } else {
686
+ $upload.text(lang.uploadStart);
687
+ }
688
+ break;
689
+ }
690
+
691
+ state = val;
692
+ updateStatus();
693
+
694
+ }
695
+
696
+ if (!_this.getQueueCount()) {
697
+ $upload.addClass('disabled')
698
+ } else {
699
+ $upload.removeClass('disabled')
700
+ }
701
+
702
+ }
703
+
704
+ function updateStatus() {
705
+ var text = '', stats;
706
+
707
+ if (state === 'ready') {
708
+ text = lang.updateStatusReady.replace('_', fileCount).replace('_KB', WebUploader.formatSize(fileSize));
709
+ } else if (state === 'confirm') {
710
+ stats = uploader.getStats();
711
+ if (stats.uploadFailNum) {
712
+ text = lang.updateStatusConfirm.replace('_', stats.successNum).replace('_', stats.successNum);
713
+ }
714
+ } else {
715
+ stats = uploader.getStats();
716
+ text = lang.updateStatusFinish.replace('_', fileCount).replace('_KB', WebUploader.formatSize(fileSize)).replace('_', stats.successNum);
717
+
718
+ if (stats.uploadFailNum) {
719
+ text += lang.updateStatusError.replace('_', stats.uploadFailNum);
720
+ }
721
+ }
722
+
723
+ $info.html(text);
724
+ }
725
+
726
+ uploader.on('fileQueued', function (file) {
727
+ fileCount++;
728
+ fileSize += file.size;
729
+
730
+ if (fileCount === 1) {
731
+ $placeHolder.addClass('element-invisible');
732
+ $statusBar.show();
733
+ }
734
+
735
+ addFile(file);
736
+ });
737
+
738
+ uploader.on('fileDequeued', function (file) {
739
+ if (file.ext && acceptExtensions.indexOf(file.ext.toLowerCase()) != -1 && file.size <= imageMaxSize) {
740
+ fileCount--;
741
+ fileSize -= file.size;
742
+ }
743
+
744
+ removeFile(file);
745
+ updateTotalProgress();
746
+ });
747
+
748
+ uploader.on('filesQueued', function (file) {
749
+ if (!uploader.isInProgress() && (state == 'pedding' || state == 'finish' || state == 'confirm' || state == 'ready')) {
750
+ setState('ready');
751
+ }
752
+ updateTotalProgress();
753
+ });
754
+
755
+ uploader.on('all', function (type, files) {
756
+ switch (type) {
757
+ case 'uploadFinished':
758
+ setState('confirm', files);
759
+ break;
760
+ case 'startUpload':
761
+ /* 添加额外的GET参数 */
762
+ var params = utils.serializeParam(editor.queryCommandValue('serverparam')) || '',
763
+ url = utils.formatUrl(actionUrl + (actionUrl.indexOf('?') == -1 ? '?' : '&') + 'encode=utf-8&' + params);
764
+ uploader.option('server', url);
765
+ setState('uploading', files);
766
+ break;
767
+ case 'stopUpload':
768
+ setState('paused', files);
769
+ break;
770
+ }
771
+ });
772
+
773
+ uploader.on('uploadBeforeSend', function (file, data, header) {
774
+ //这里可以通过data对象添加POST参数
775
+ if (actionUrl.toLowerCase().indexOf('jsp') != -1) {
776
+ header['X-Requested-With'] = 'XMLHttpRequest';
777
+ }
778
+ });
779
+
780
+ uploader.on('uploadProgress', function (file, percentage) {
781
+ var $li = $('#' + file.id),
782
+ $percent = $li.find('.progress span');
783
+
784
+ $percent.css('width', percentage * 100 + '%');
785
+ percentages[file.id][1] = percentage;
786
+ updateTotalProgress();
787
+ });
788
+
789
+ uploader.on('uploadSuccess', function (file, ret) {
790
+ var $file = $('#' + file.id);
791
+ try {
792
+ var responseText = (ret._raw || ret),
793
+ json = utils.str2json(responseText);
794
+ json = editor.options.serverResponsePrepare(json);
795
+ if (json.state == 'SUCCESS') {
796
+ _this.imageList.push(json);
797
+ $file.append('<span class="success"></span>');
798
+ // 触发上传图片事件
799
+ editor.fireEvent("uploadsuccess", {
800
+ res: json,
801
+ type: 'image'
802
+ });
803
+ } else {
804
+ $file.find('.error').text(json.state).show();
805
+ }
806
+ } catch (e) {
807
+ $file.find('.error').text(lang.errorServerUpload).show();
808
+ }
809
+ });
810
+
811
+ uploader.on('uploadError', function (file, code) {
812
+ });
813
+ uploader.on('error', function (code, param1, param2) {
814
+ if (code === 'F_EXCEED_SIZE') {
815
+ editor.getOpt('tipError')(lang.errorExceedSize + ' ' + (param1 / 1024 / 1024).toFixed(1) + 'MB');
816
+ } else {
817
+ console.log('error', code, param1, param2);
818
+ }
819
+ });
820
+ uploader.on('uploadComplete', function (file, ret) {
821
+ });
822
+
823
+ $upload.on('click', function () {
824
+ if ($(this).hasClass('disabled')) {
825
+ return false;
826
+ }
827
+
828
+ if (state === 'ready') {
829
+ uploader.upload();
830
+ } else if (state === 'paused') {
831
+ uploader.upload();
832
+ } else if (state === 'uploading') {
833
+ uploader.stop();
834
+ }
835
+ });
836
+
837
+ $upload.addClass('state-' + state);
838
+ updateTotalProgress();
839
+ },
840
+ getQueueCount: function () {
841
+ var file, i, status, readyFile = 0, files = this.uploader.getFiles();
842
+ for (i = 0; file = files[i++];) {
843
+ status = file.getStatus();
844
+ if (status == 'queued' || status == 'uploading' || status == 'progress') readyFile++;
845
+ }
846
+ return readyFile;
847
+ },
848
+ destroy: function () {
849
+ this.$wrap.remove();
850
+ },
851
+ getInsertList: function () {
852
+ var i, data, list = [],
853
+ align = getAlign(),
854
+ prefix = editor.getOpt('imageUrlPrefix');
855
+ for (i = 0; i < this.imageList.length; i++) {
856
+ data = this.imageList[i];
857
+ list.push({
858
+ src: prefix + data.url,
859
+ _src: prefix + data.url,
860
+ alt: data.original,
861
+ floatStyle: align
862
+ });
863
+ }
864
+ return list;
865
+ }
866
+ };
867
+
868
+
869
+ /* 在线图片 */
870
+ function OnlineImage(target) {
871
+ this.container = utils.isString(target) ? document.getElementById(target) : target;
872
+ this.init();
873
+ }
874
+
875
+ OnlineImage.prototype = {
876
+ init: function () {
877
+ this.reset();
878
+ this.initEvents();
879
+ },
880
+ /* 初始化容器 */
881
+ initContainer: function () {
882
+ this.container.innerHTML = '';
883
+ this.list = document.createElement('ul');
884
+ this.clearFloat = document.createElement('li');
885
+
886
+ domUtils.addClass(this.list, 'list');
887
+ domUtils.addClass(this.clearFloat, 'clearFloat');
888
+
889
+ this.list.appendChild(this.clearFloat);
890
+ this.container.appendChild(this.list);
891
+ },
892
+ /* 初始化滚动事件,滚动到地步自动拉取数据 */
893
+ initEvents: function () {
894
+ var _this = this;
895
+
896
+ /* 滚动拉取图片 */
897
+ domUtils.on($G('imageList'), 'scroll', function (e) {
898
+ var panel = this;
899
+ if (panel.scrollHeight - (panel.offsetHeight + panel.scrollTop) < 10) {
900
+ _this.getImageData();
901
+ }
902
+ });
903
+ /* 选中图片 */
904
+ domUtils.on(this.container, 'click', function (e) {
905
+ var target = e.target || e.srcElement,
906
+ li = target.parentNode;
907
+
908
+ if (li.tagName.toLowerCase() == 'li') {
909
+ if (domUtils.hasClass(li, 'selected')) {
910
+ domUtils.removeClasses(li, 'selected');
911
+ } else {
912
+ domUtils.addClass(li, 'selected');
913
+ }
914
+ }
915
+ });
916
+ },
917
+ /* 初始化第一次的数据 */
918
+ initData: function () {
919
+
920
+ /* 拉取数据需要使用的值 */
921
+ this.state = 0;
922
+ this.listSize = editor.getOpt('imageManagerListSize');
923
+ this.listIndex = 0;
924
+ this.listEnd = false;
925
+
926
+ /* 第一次拉取数据 */
927
+ this.getImageData();
928
+ },
929
+ /* 重置界面 */
930
+ reset: function () {
931
+ this.initContainer();
932
+ this.initData();
933
+ },
934
+ /* 向后台拉取图片列表数据 */
935
+ getImageData: function () {
936
+ var _this = this;
937
+
938
+ if (!_this.listEnd && !this.isLoadingData) {
939
+ this.isLoadingData = true;
940
+ var url = editor.getActionUrl(editor.getOpt('imageManagerActionName')),
941
+ isJsonp = utils.isCrossDomainUrl(url);
942
+ ajax.request(url, {
943
+ 'timeout': 100000,
944
+ 'dataType': isJsonp ? 'jsonp' : '',
945
+ 'headers': editor.options.serverHeaders || {},
946
+ 'data': utils.extend({
947
+ start: this.listIndex,
948
+ size: this.listSize
949
+ }, editor.queryCommandValue('serverparam')),
950
+ 'method': 'get',
951
+ 'onsuccess': function (r) {
952
+ try {
953
+ var json = isJsonp ? r : eval('(' + r.responseText + ')');
954
+ json = editor.options.serverResponsePrepare(json);
955
+ if (json.state === 'SUCCESS') {
956
+ _this.pushData(json.list);
957
+ _this.listIndex = parseInt(json.start) + parseInt(json.list.length);
958
+ if (_this.listIndex >= json.total) {
959
+ _this.listEnd = true;
960
+ }
961
+ _this.isLoadingData = false;
962
+ }
963
+ } catch (e) {
964
+ if (r.responseText.indexOf('ue_separate_ue') != -1) {
965
+ var list = r.responseText.split(r.responseText);
966
+ _this.pushData(list);
967
+ _this.listIndex = parseInt(list.length);
968
+ _this.listEnd = true;
969
+ _this.isLoadingData = false;
970
+ }
971
+ }
972
+ },
973
+ 'onerror': function () {
974
+ _this.isLoadingData = false;
975
+ }
976
+ });
977
+ }
978
+ },
979
+ /* 添加图片到列表界面上 */
980
+ pushData: function (list) {
981
+ var i, item, img, icon, _this = this,
982
+ urlPrefix = editor.getOpt('imageManagerUrlPrefix');
983
+ for (i = 0; i < list.length; i++) {
984
+ if (list[i] && list[i].url) {
985
+ item = document.createElement('li');
986
+ img = document.createElement('img');
987
+ icon = document.createElement('span');
988
+
989
+ domUtils.on(img, 'load', (function (image) {
990
+ return function () {
991
+ _this.scale(image, image.parentNode.offsetWidth, image.parentNode.offsetHeight);
992
+ }
993
+ })(img));
994
+ img.width = 113;
995
+ img.setAttribute('src', urlPrefix + list[i].url + (list[i].url.indexOf('?') == -1 ? '?noCache=' : '&noCache=') + (+new Date()).toString(36));
996
+ img.setAttribute('_src', urlPrefix + list[i].url);
997
+ domUtils.addClass(icon, 'icon');
998
+
999
+ item.appendChild(img);
1000
+ item.appendChild(icon);
1001
+ this.list.insertBefore(item, this.clearFloat);
1002
+ }
1003
+ }
1004
+ },
1005
+ /* 改变图片大小 */
1006
+ scale: function (img, w, h, type) {
1007
+ var ow = img.width,
1008
+ oh = img.height;
1009
+
1010
+ if (type == 'justify') {
1011
+ if (ow >= oh) {
1012
+ img.width = w;
1013
+ img.height = h * oh / ow;
1014
+ img.style.marginLeft = '-' + parseInt((img.width - w) / 2) + 'px';
1015
+ } else {
1016
+ img.width = w * ow / oh;
1017
+ img.height = h;
1018
+ img.style.marginTop = '-' + parseInt((img.height - h) / 2) + 'px';
1019
+ }
1020
+ } else {
1021
+ if (ow >= oh) {
1022
+ img.width = w * ow / oh;
1023
+ img.height = h;
1024
+ img.style.marginLeft = '-' + parseInt((img.width - w) / 2) + 'px';
1025
+ } else {
1026
+ img.width = w;
1027
+ img.height = h * oh / ow;
1028
+ img.style.marginTop = '-' + parseInt((img.height - h) / 2) + 'px';
1029
+ }
1030
+ }
1031
+ },
1032
+ getInsertList: function () {
1033
+ var i, lis = this.list.children, list = [], align = getAlign();
1034
+ for (i = 0; i < lis.length; i++) {
1035
+ if (domUtils.hasClass(lis[i], 'selected')) {
1036
+ var img = lis[i].firstChild,
1037
+ src = img.getAttribute('_src');
1038
+ list.push({
1039
+ src: src,
1040
+ _src: src,
1041
+ alt: src.substr(src.lastIndexOf('/') + 1),
1042
+ floatStyle: align
1043
+ });
1044
+ }
1045
+
1046
+ }
1047
+ return list;
1048
+ }
1049
+ };
1050
+
1051
+ })();