123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553 |
- /*
- * Created by ALL-INKL.COM - Neue Medien Muennich - 04. Feb 2014
- * Licensed under the terms of GPL, LGPL and MPL licenses.
- */
- CKEDITOR.dialog.add("base64imageDialog", function (editor) {
- var t = null,
- selectedImg = null,
- orgWidth = null, orgHeight = null,
- imgPreview = null, urlCB = null, urlI = null, fileCB = null, imgScal = 1, lock = true;
- /* Check File Reader Support */
- function fileSupport() {
- var r = false, n = null;
- try {
- if (FileReader) {
- var n = document.createElement("input");
- if (n && "files" in n) r = true;
- }
- } catch (e) {
- r = false;
- }
- n = null;
- return r;
- }
- var fsupport = fileSupport();
- /* Load preview image */
- function imagePreviewLoad(s) {
- /* no preview */
- if (typeof (s) != "string" || !s) {
- imgPreview.getElement().setHtml("");
- return;
- }
- /* Create image */
- var i = new Image();
- /* Display loading text in preview element */
- imgPreview.getElement().setHtml("Loading...");
- /* When image is loaded */
- i.onload = function () {
- /* Remove preview */
- imgPreview.getElement().setHtml("");
- /* Set attributes */
- if (orgWidth == null || orgHeight == null) {
- if (this.width > 614) {
- this.width = this.width / 8;
- this.height = this.height / 8;
- }
- t.setValueOf("tab-properties", "width", this.width);
- t.setValueOf("tab-properties", "height", this.height);
- imgScal = 1;
- if (this.height > 0 && this.width > 0) imgScal = this.width / this.height;
- if (imgScal <= 0) imgScal = 1;
- } else {
- orgWidth = null;
- orgHeight = null;
- }
- this.id = editor.id + "previewimage";
- this.setAttribute("style", "max-width:400px;max-height:100px;");
- this.setAttribute("alt", "");
- /* Insert preview image */
- try {
- var p = imgPreview.getElement().$;
- if (p) p.appendChild(this);
- } catch (e) {
- }
- };
- /* Error Function */
- i.onerror = function () {
- imgPreview.getElement().setHtml("");
- };
- i.onabort = function () {
- imgPreview.getElement().setHtml("");
- };
- /* Load image */
- i.src = s;
- }
- /* Change input values and preview image */
- function imagePreview(src) {
- /* Remove preview */
- imgPreview.getElement().setHtml("");
- if (src == "base64") {
- /* Disable Checkboxes */
- if (urlCB) urlCB.setValue(false, true);
- if (fileCB) fileCB.setValue(false, true);
- } else if (src == "url") {
- /* Ensable Image URL Checkbox */
- if (urlCB) urlCB.setValue(true, true);
- if (fileCB) fileCB.setValue(false, true);
- /* Load preview image */
- if (urlI) imagePreviewLoad(urlI.getValue());
- } else if (fsupport) {
- /* Ensable Image File Checkbox */
- if (urlCB) urlCB.setValue(false, true);
- if (fileCB) fileCB.setValue(true, true);
- /* Read file and load preview */
- var fileI = t.getContentElement("tab-source", "file");
- var n = null;
- try {
- n = fileI.getInputElement().$;
- } catch (e) {
- n = null;
- }
- if (n && "files" in n && n.files && n.files.length > 0 && n.files[0]) {
- if ("type" in n.files[0] && !n.files[0].type.match("image.*")) return;
- if (!FileReader) return;
- if (n.files[0].size >= 3000000) {
- alert('圖片容量 大於 3MB, 請重新調整');
- return false;
- }
- imgPreview.getElement().setHtml("Loading...");
- var fr = new FileReader();
- fr.onload = (function (f) {
- return function (e) {
- imgPreview.getElement().setHtml("");
- imagePreviewLoad(e.target.result);
- };
- })(n.files[0]);
- fr.onerror = function () {
- imgPreview.getElement().setHtml("");
- };
- fr.onabort = function () {
- imgPreview.getElement().setHtml("");
- };
- fr.readAsDataURL(n.files[0]);
- }
- }
- };
- /* Calculate image dimensions */
- function getImageDimensions() {
- var o = {
- "w": t.getContentElement("tab-properties", "width").getValue(),
- "h": t.getContentElement("tab-properties", "height").getValue(),
- "uw": "px",
- "uh": "px"
- };
- if (o.w.indexOf("%") >= 0) o.uw = "%";
- if (o.h.indexOf("%") >= 0) o.uh = "%";
- o.w = parseInt(o.w, 10);
- o.h = parseInt(o.h, 10);
- if (isNaN(o.w)) o.w = 0;
- if (isNaN(o.h)) o.h = 0;
- return o;
- }
- /* Set image dimensions */
- function imageDimensions(src) {
- var o = getImageDimensions();
- var u = "px";
- if (src == "width") {
- if (o.uw == "%") u = "%";
- o.h = Math.round(o.w / imgScal);
- } else {
- if (o.uh == "%") u = "%";
- o.w = Math.round(o.h * imgScal);
- }
- if (u == "%") {
- o.w += "%";
- o.h += "%";
- }
- t.getContentElement("tab-properties", "width").setValue(o.w),
- t.getContentElement("tab-properties", "height").setValue(o.h)
- }
- /* Set integer Value */
- function integerValue(elem) {
- var v = elem.getValue(), u = "";
- if (v.indexOf("%") >= 0) u = "%";
- v = parseInt(v, 10);
- if (isNaN(v)) v = 0;
- elem.setValue(v + u);
- }
- if (fsupport) {
- /* Dialog with file and url image source */
- var sourceElements = [
- {
- type: "hbox",
- widths: ["70px"],
- children: [
- {
- type: "checkbox",
- id: "urlcheckbox",
- style: "margin-top:5px",
- label: editor.lang.common.url + ":"
- },
- {
- type: "text",
- id: "url",
- label: "",
- onChange: function () {
- imagePreview("url");
- }
- }
- ]
- },
- {
- type: "hbox",
- widths: ["70px"],
- children: [
- {
- type: "checkbox",
- id: "filecheckbox",
- style: "margin-top:5px",
- label: editor.lang.common.upload + ":"
- },
- {
- type: "file",
- id: "file",
- label: "",
- onChange: function () {
- imagePreview("file");
- }
- }
- ]
- },
- {
- type: "html",
- id: "preview",
- html: new CKEDITOR.template("<div style=\"text-align:center;\"></div>").output()
- }
- ];
- } else {
- /* Dialog with url image source */
- var sourceElements = [
- {
- type: "text",
- id: "url",
- label: editor.lang.common.url,
- onChange: function () {
- imagePreview("url");
- }
- },
- {
- type: "html",
- id: "preview",
- html: new CKEDITOR.template("<div style=\"text-align:center;\"></div>").output()
- }
- ];
- }
- /* Dialog */
- return {
- title: editor.lang.common.image,
- minWidth: 450,
- minHeight: 180,
- onLoad: function () {
- if (fsupport) {
- /* Get checkboxes */
- urlCB = this.getContentElement("tab-source", "urlcheckbox");
- fileCB = this.getContentElement("tab-source", "filecheckbox");
- /* Checkbox Events */
- urlCB.getInputElement().on("click", function () {
- imagePreview("url");
- });
- fileCB.getInputElement().on("click", function () {
- imagePreview("file");
- });
- }
- /* Get url input element */
- urlI = this.getContentElement("tab-source", "url");
- /* Get image preview element */
- imgPreview = this.getContentElement("tab-source", "preview");
- /* Constrain proportions or not */
- this.getContentElement("tab-properties", "lock").getInputElement().on("click", function () {
- if (this.getValue()) lock = true; else lock = false;
- if (lock) imageDimensions("width");
- }, this.getContentElement("tab-properties", "lock"));
- /* Change Attributes Events */
- this.getContentElement("tab-properties", "width").getInputElement().on("keyup", function () {
- if (lock) imageDimensions("width");
- });
- this.getContentElement("tab-properties", "height").getInputElement().on("keyup", function () {
- if (lock) imageDimensions("height");
- });
- this.getContentElement("tab-properties", "vmargin").getInputElement().on("keyup", function () {
- integerValue(this);
- }, this.getContentElement("tab-properties", "vmargin"));
- this.getContentElement("tab-properties", "hmargin").getInputElement().on("keyup", function () {
- integerValue(this);
- }, this.getContentElement("tab-properties", "hmargin"));
- this.getContentElement("tab-properties", "border").getInputElement().on("keyup", function () {
- integerValue(this);
- }, this.getContentElement("tab-properties", "border"));
- },
- onShow: function () {
- /* Remove preview */
- imgPreview.getElement().setHtml("");
- t = this, orgWidth = null, orgHeight = null, imgScal = 1, lock = true;
- /* selected image or null */
- selectedImg = editor.getSelection();
- if (selectedImg) selectedImg = selectedImg.getSelectedElement();
- if (!selectedImg || selectedImg.getName() !== "img") selectedImg = null;
- /* Set input values */
- t.setValueOf("tab-properties", "lock", lock);
- t.setValueOf("tab-properties", "vmargin", "0");
- t.setValueOf("tab-properties", "hmargin", "0");
- t.setValueOf("tab-properties", "border", "0");
- t.setValueOf("tab-properties", "align", "none");
- if (selectedImg) {
- /* Set input values from selected image */
- if (typeof (selectedImg.getAttribute("width")) == "string") orgWidth = selectedImg.getAttribute("width");
- if (typeof (selectedImg.getAttribute("height")) == "string") orgHeight = selectedImg.getAttribute("height");
- if ((orgWidth == null || orgHeight == null) && selectedImg.$) {
- orgWidth = selectedImg.$.width;
- orgHeight = selectedImg.$.height;
- }
- if (orgWidth != null && orgHeight != null) {
- t.setValueOf("tab-properties", "width", orgWidth);
- t.setValueOf("tab-properties", "height", orgHeight);
- orgWidth = parseInt(orgWidth, 10);
- orgHeight = parseInt(orgHeight, 10);
- imgScal = 1;
- if (!isNaN(orgWidth) && !isNaN(orgHeight) && orgHeight > 0 && orgWidth > 0) imgScal = orgWidth / orgHeight;
- if (imgScal <= 0) imgScal = 1;
- }
- if (typeof (selectedImg.getAttribute("src")) == "string") {
- if (selectedImg.getAttribute("src").indexOf("data:") === 0) {
- imagePreview("base64");
- imagePreviewLoad(selectedImg.getAttribute("src"));
- } else {
- t.setValueOf("tab-source", "url", selectedImg.getAttribute("src"));
- }
- }
- if (typeof (selectedImg.getAttribute("alt")) == "string") t.setValueOf("tab-properties", "alt", selectedImg.getAttribute("alt"));
- if (typeof (selectedImg.getAttribute("hspace")) == "string") t.setValueOf("tab-properties", "hmargin", selectedImg.getAttribute("hspace"));
- if (typeof (selectedImg.getAttribute("vspace")) == "string") t.setValueOf("tab-properties", "vmargin", selectedImg.getAttribute("vspace"));
- if (typeof (selectedImg.getAttribute("border")) == "string") t.setValueOf("tab-properties", "border", selectedImg.getAttribute("border"));
- if (typeof (selectedImg.getAttribute("align")) == "string") {
- switch (selectedImg.getAttribute("align")) {
- case "top":
- case "text-top":
- t.setValueOf("tab-properties", "align", "top");
- break;
- case "baseline":
- case "bottom":
- case "text-bottom":
- t.setValueOf("tab-properties", "align", "bottom");
- break;
- case "left":
- t.setValueOf("tab-properties", "align", "left");
- break;
- case "right":
- t.setValueOf("tab-properties", "align", "right");
- break;
- }
- }
- t.selectPage("tab-properties");
- }
- },
- onOk: function () {
- /* Get image source */
- var src = "";
- try {
- src = CKEDITOR.document.getById(editor.id + "previewimage").$.src;
- } catch (e) {
- src = "";
- }
- if (typeof (src) != "string" || src == null || src === "") return;
- /* selected image or new image */
- if (selectedImg) var newImg = selectedImg; else var newImg = editor.document.createElement("img");
- newImg.setAttribute("src", src);
- src = null;
- /* Set attributes */
- newImg.setAttribute("alt", t.getValueOf("tab-properties", "alt").replace(/^\s+/, "").replace(/\s+$/, ""));
- var attr = {
- "width": ["width", "width:#;", "integer", 1],
- "height": ["height", "height:#;", "integer", 1],
- "vmargin": ["vspace", "margin-top:#;margin-bottom:#;", "integer", 0],
- "hmargin": ["hspace", "margin-left:#;margin-right:#;", "integer", 0],
- "align": ["align", ""],
- "border": ["border", "border:# solid black;", "integer", 0]
- }, css = [], value, cssvalue, attrvalue, k;
- for (k in attr) {
- value = t.getValueOf("tab-properties", k);
- attrvalue = value;
- cssvalue = value;
- unit = "px";
- if (k == "align") {
- switch (value) {
- case "top":
- case "bottom":
- attr[k][1] = "vertical-align:#;";
- break;
- case "left":
- case "right":
- attr[k][1] = "float:#;";
- break;
- default:
- value = null;
- break;
- }
- }
- if (attr[k][2] == "integer") {
- if (value.indexOf("%") >= 0) unit = "%";
- value = parseInt(value, 10);
- if (isNaN(value)) value = null; else if (value < attr[k][3]) value = null;
- if (value != null) {
- if (unit == "%") {
- attrvalue = value + "%";
- cssvalue = value + "%";
- } else {
- attrvalue = value;
- cssvalue = value + "px";
- }
- }
- }
- if (value != null) {
- newImg.setAttribute(attr[k][0], attrvalue);
- css.push(attr[k][1].replace(/#/g, cssvalue));
- }
- }
- if (css.length > 0) newImg.setAttribute("style", css.join(""));
- /* Insert new image */
- if (!selectedImg) editor.insertElement(newImg);
- /* Resize image */
- if (editor.plugins.imageresize) editor.plugins.imageresize.resize(editor, newImg, 800, 800);
- },
- /* Dialog form */
- contents: [
- {
- id: "tab-source",
- label: editor.lang.common.generalTab,
- elements: sourceElements
- },
- {
- id: "tab-properties",
- label: editor.lang.common.advancedTab,
- elements: [
- {
- type: "text",
- id: "alt",
- label: editor.lang.base64image.alt
- },
- {
- type: 'hbox',
- widths: ["15%", "15%", "70%"],
- children: [
- {
- type: "text",
- width: "45px",
- id: "width",
- label: editor.lang.common.width
- },
- {
- type: "text",
- width: "45px",
- id: "height",
- label: editor.lang.common.height
- },
- {
- type: "checkbox",
- id: "lock",
- label: editor.lang.base64image.lockRatio,
- style: "margin-top:18px;"
- }
- ]
- },
- {
- type: 'hbox',
- widths: ["23%", "30%", "30%", "17%"],
- style: "margin-top:10px;",
- children: [
- {
- type: "select",
- id: "align",
- label: editor.lang.common.align,
- items: [
- [editor.lang.common.notSet, "none"],
- [editor.lang.common.alignTop, "top"],
- [editor.lang.common.alignBottom, "bottom"],
- [editor.lang.common.alignLeft, "left"],
- [editor.lang.common.alignRight, "right"]
- ]
- },
- {
- type: "text",
- width: "45px",
- id: "vmargin",
- label: editor.lang.base64image.vSpace
- },
- {
- type: "text",
- width: "45px",
- id: "hmargin",
- label: editor.lang.base64image.hSpace
- },
- {
- type: "text",
- width: "45px",
- id: "border",
- label: editor.lang.base64image.border
- }
- ]
- }
- ]
- }
- ]
- };
- });
|