1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644 |
- (function(editors, elFinder) {
- if (typeof define === 'function' && define.amd) {
- define(['elfinder'], editors);
- } else if (elFinder) {
- var optEditors = elFinder.prototype._options.commandsOptions.edit.editors;
- elFinder.prototype._options.commandsOptions.edit.editors = optEditors.concat(editors(elFinder));
- }
- }(function(elFinder) {
- "use strict";
- var apps = {},
- // get query of getfile
- getfile = window.location.search.match(/getfile=([a-z]+)/),
- useRequire = elFinder.prototype.hasRequire,
- ext2mime = {
- bmp: 'image/x-ms-bmp',
- dng: 'image/x-adobe-dng',
- gif: 'image/gif',
- jpeg: 'image/jpeg',
- jpg: 'image/jpeg',
- pdf: 'application/pdf',
- png: 'image/png',
- ppm: 'image/x-portable-pixmap',
- psd: 'image/vnd.adobe.photoshop',
- pxd: 'image/x-pixlr-data',
- svg: 'image/svg+xml',
- tiff: 'image/tiff',
- webp: 'image/webp',
- xcf: 'image/x-xcf',
- sketch: 'application/x-sketch',
- ico: 'image/x-icon',
- dds: 'image/vnd-ms.dds',
- emf: 'application/x-msmetafile'
- },
- mime2ext,
- getExtention = function(mime, fm, jpeg) {
- if (!mime2ext) {
- mime2ext = fm.arrayFlip(ext2mime);
- }
- var ext = mime2ext[mime] || fm.mimeTypes[mime];
- if (!jpeg) {
- if (ext === 'jpeg') {
- ext = 'jpg';
- }
- } else {
- if (ext === 'jpg') {
- ext = 'jpeg';
- }
- }
- return ext;
- },
- changeImageType = function(src, toMime) {
- var dfd = $.Deferred();
- try {
- var canvas = document.createElement('canvas'),
- ctx = canvas.getContext('2d'),
- img = new Image(),
- conv = function() {
- var url = canvas.toDataURL(toMime),
- mime, m;
- if (m = url.match(/^data:([a-z0-9]+\/[a-z0-9.+-]+)/i)) {
- mime = m[1];
- } else {
- mime = '';
- }
- if (mime.toLowerCase() === toMime.toLowerCase()) {
- dfd.resolve(canvas.toDataURL(toMime), canvas);
- } else {
- dfd.reject();
- }
- };
- img.src = src;
- $(img).on('load', function() {
- try {
- canvas.width = img.width;
- canvas.height = img.height;
- ctx.drawImage(img, 0, 0);
- conv();
- } catch(e) {
- dfd.reject();
- }
- }).on('error', function () {
- dfd.reject();
- });
- return dfd;
- } catch(e) {
- return dfd.reject();
- }
- },
- initImgTag = function(id, file, content, fm) {
- var node = $(this).children('img:first').data('ext', getExtention(file.mime, fm)),
- spnr = $('<div class="elfinder-edit-spinner elfinder-edit-image"></div>')
- .html('<span class="elfinder-spinner-text">' + fm.i18n('ntfloadimg') + '</span><span class="elfinder-spinner"></span>')
- .hide()
- .appendTo(this),
- setup = function() {
- node.attr('id', id+'-img')
- .attr('src', url || content)
- .css({'height':'', 'max-width':'100%', 'max-height':'100%', 'cursor':'pointer'})
- .data('loading', function(done) {
- var btns = node.closest('.elfinder-dialog').find('button,.elfinder-titlebar-button');
- btns.prop('disabled', !done)[done? 'removeClass' : 'addClass']('ui-state-disabled');
- node.css('opacity', done? '' : '0.3');
- spnr[done? 'hide' : 'show']();
- return node;
- });
- },
- url;
-
- if (!content.match(/^data:/)) {
- fm.openUrl(file.hash, false, function(v) {
- url = v;
- node.attr('_src', content);
- setup();
- });
- } else {
- setup();
- }
- },
- imgBase64 = function(node, mime) {
- var style = node.attr('style'),
- img, canvas, ctx, data;
- try {
- // reset css for getting image size
- node.attr('style', '');
- // img node
- img = node.get(0);
- // New Canvas
- canvas = document.createElement('canvas');
- canvas.width = img.width;
- canvas.height = img.height;
- // restore css
- node.attr('style', style);
- // Draw Image
- canvas.getContext('2d').drawImage(img, 0, 0);
- // To Base64
- data = canvas.toDataURL(mime);
- } catch(e) {
- data = node.attr('src');
- }
- return data;
- },
- iframeClose = function(ifm) {
- var $ifm = $(ifm),
- dfd = $.Deferred().always(function() {
- $ifm.off('load', load);
- }),
- ab = 'about:blank',
- chk = function() {
- tm = setTimeout(function() {
- var src;
- try {
- src = base.contentWindow.location.href;
- } catch(e) {
- src = null;
- }
- if (src === ab) {
- dfd.resolve();
- } else if (--cnt > 0){
- chk();
- } else {
- dfd.reject();
- }
- }, 500);
- },
- load = function() {
- tm && clearTimeout(tm);
- dfd.resolve();
- },
- cnt = 20, // 500ms * 20 = 10sec wait
- tm;
- $ifm.one('load', load);
- ifm.src = ab;
- chk();
- return dfd;
- };
-
- // check getfile callback function
- if (getfile) {
- getfile = getfile[1];
- if (getfile === 'ckeditor') {
- elFinder.prototype._options.getFileCallback = function(file, fm) {
- window.opener.CKEDITOR.tools.callFunction((function() {
- var reParam = new RegExp('(?:[\?&]|&)CKEditorFuncNum=([^&]+)', 'i'),
- match = window.location.search.match(reParam);
- return (match && match.length > 1) ? match[1] : '';
- })(), fm.convAbsUrl(file.url));
- fm.destroy();
- window.close();
- };
- }
- }
-
- // return editors Array
- return [
- {
- // tui.image-editor - https://github.com/nhnent/tui.image-editor
- info : {
- id: 'tuiimgedit',
- name: 'TUI Image Editor',
- iconImg: 'img/editor-icons.png 0 -48',
- dataScheme: true,
- schemeContent: true,
- openMaximized: true,
- canMakeEmpty: false,
- integrate: {
- title: 'TOAST UI Image Editor',
- link: 'http://ui.toast.com/tui-image-editor/'
- }
- },
- // MIME types to accept
- mimes : ['image/jpeg', 'image/png', 'image/gif', 'image/svg+xml', 'image/x-ms-bmp'],
- // HTML of this editor
- html : '<div class="elfinder-edit-imageeditor"><canvas></canvas></div>',
- // called on initialization of elFinder cmd edit (this: this editor's config object)
- setup : function(opts, fm) {
- if (fm.UA.ltIE8 || fm.UA.Mobile) {
- this.disabled = true;
- } else {
- this.opts = Object.assign({
- version: 'v3.9.0'
- }, opts.extraOptions.tuiImgEditOpts || {}, {
- iconsPath : fm.baseUrl + 'img/tui-',
- theme : {}
- });
- if (!fm.isSameOrigin(this.opts.iconsPath)) {
- this.disabled = true;
- fm.debug('warning', 'Setting `commandOptions.edit.extraOptions.tuiImgEditOpts.iconsPath` MUST follow the same origin policy.');
- }
- }
- },
- // Initialization of editing node (this: this editors HTML node)
- init : function(id, file, content, fm) {
- this.data('url', content);
- },
- load : function(base) {
- var self = this,
- fm = this.fm,
- dfrd = $.Deferred(),
- cdns = fm.options.cdns,
- ver = self.confObj.opts.version,
- init = function(editor) {
- var $base = $(base),
- bParent = $base.parent(),
- opts = self.confObj.opts,
- iconsPath = opts.iconsPath,
- tmpContainer = $('<div class="tui-image-editor-container">').appendTo(bParent),
- tmpDiv = [
- $('<div class="tui-image-editor-submenu"></div>').appendTo(tmpContainer),
- $('<div class="tui-image-editor-controls"></div>').appendTo(tmpContainer)
- ],
- iEditor = new editor(base, {
- includeUI: {
- loadImage: {
- path: $base.data('url'),
- name: self.file.name
- },
- theme: Object.assign(opts.theme, {
- 'menu.normalIcon.path': iconsPath + 'icon-d.svg',
- 'menu.normalIcon.name': 'icon-d',
- 'menu.activeIcon.path': iconsPath + 'icon-b.svg',
- 'menu.activeIcon.name': 'icon-b',
- 'menu.disabledIcon.path': iconsPath + 'icon-a.svg',
- 'menu.disabledIcon.name': 'icon-a',
- 'menu.hoverIcon.path': iconsPath + 'icon-c.svg',
- 'menu.hoverIcon.name': 'icon-c',
- 'submenu.normalIcon.path': iconsPath + 'icon-d.svg',
- 'submenu.normalIcon.name': 'icon-d',
- 'submenu.activeIcon.path': iconsPath + 'icon-c.svg',
- 'submenu.activeIcon.name': 'icon-c'
- }),
- initMenu: 'filter',
- menuBarPosition: 'bottom'
- },
- cssMaxWidth: Math.max(300, bParent.width()),
- cssMaxHeight: Math.max(200, bParent.height() - (tmpDiv[0].height() + tmpDiv[1].height() + 3 /*margin*/)),
- usageStatistics: false
- }),
- canvas = $base.find('canvas:first').get(0),
- zoom = function(v) {
- if (typeof v !== 'undefined') {
- var c = $(canvas),
- w = parseInt(c.attr('width')),
- h = parseInt(c.attr('height')),
- a = w / h,
- mw, mh;
- if (v === 0) {
- mw = w;
- mh = h;
- } else {
- mw = parseInt(c.css('max-width')) + Number(v);
- mh = mw / a;
- if (mw > w && mh > h) {
- mw = w;
- mh = h;
- }
- }
- per.text(Math.round(mw / w * 100) + '%');
- iEditor.resizeCanvasDimension({width: mw, height: mh});
- // continually change more
- if (zoomMore) {
- setTimeout(function() {
- zoomMore && zoom(v);
- }, 50);
- }
- }
- },
- zup = $('<span class="ui-icon ui-icon-plusthick"></span>').data('val', 10),
- zdown = $('<span class="ui-icon ui-icon-minusthick"></span>').data('val', -10),
- per = $('<button></button>').css('width', '4em').text('%').attr('title', '100%').data('val', 0),
- quty, qutyTm, zoomTm, zoomMore;
- tmpContainer.remove();
- $base.removeData('url').data('mime', self.file.mime);
- // jpeg quality controls
- if (self.file.mime === 'image/jpeg') {
- $base.data('quality', fm.storage('jpgQuality') || fm.option('jpgQuality'));
- quty = $('<input type="number" class="ui-corner-all elfinder-resize-quality elfinder-tabstop"/>')
- .attr('min', '1')
- .attr('max', '100')
- .attr('title', '1 - 100')
- .on('change', function() {
- var q = quty.val();
- $base.data('quality', q);
- qutyTm && cancelAnimationFrame(qutyTm);
- qutyTm = requestAnimationFrame(function() {
- canvas.toBlob(function(blob) {
- blob && quty.next('span').text(' (' + fm.formatSize(blob.size) + ')');
- }, 'image/jpeg', Math.max(Math.min(q, 100), 1) / 100);
- });
- })
- .val($base.data('quality'));
- $('<div class="ui-dialog-buttonset elfinder-edit-extras elfinder-edit-extras-quality"></div>')
- .append(
- $('<span>').html(fm.i18n('quality') + ' : '), quty, $('<span></span>')
- )
- .prependTo($base.parent().next());
- } else if (self.file.mime === 'image/svg+xml') {
- $base.closest('.ui-dialog').trigger('changeType', {
- extention: 'png',
- mime : 'image/png',
- keepEditor: true
- });
- }
- // zoom scale controls
- $('<div class="ui-dialog-buttonset elfinder-edit-extras"></div>')
- .append(
- zdown, per, zup
- )
- .attr('title', fm.i18n('scale'))
- .on('click', 'span,button', function() {
- zoom($(this).data('val'));
- })
- .on('mousedown mouseup mouseleave', 'span', function(e) {
- zoomMore = false;
- zoomTm && clearTimeout(zoomTm);
- if (e.type === 'mousedown') {
- zoomTm = setTimeout(function() {
- zoomMore = true;
- zoom($(e.target).data('val'));
- }, 500);
- }
- })
- .prependTo($base.parent().next());
- // wait canvas ready
- setTimeout(function() {
- dfrd.resolve(iEditor);
- if (quty) {
- quty.trigger('change');
- iEditor.on('redoStackChanged undoStackChanged', function() {
- quty.trigger('change');
- });
- }
- // show initial scale
- zoom(null);
- }, 100);
- // show color slider (maybe TUI-Image-Editor's bug)
- // see https://github.com/nhn/tui.image-editor/issues/153
- $base.find('.tui-colorpicker-palette-container').on('click', '.tui-colorpicker-palette-preview', function() {
- $(this).closest('.color-picker-control').height('auto').find('.tui-colorpicker-slider-container').toggle();
- });
- $base.on('click', function() {
- $base.find('.tui-colorpicker-slider-container').hide();
- });
- },
- loader;
- if (!self.confObj.editor) {
- loader = $.Deferred();
- fm.loadCss([
- cdns.tui + '/tui-color-picker/latest/tui-color-picker.css',
- cdns.tui + '/tui-image-editor/'+ver+'/tui-image-editor.css'
- ]);
- if (fm.hasRequire) {
- require.config({
- paths : {
- 'fabric/dist/fabric.require' : cdns.fabric + '/fabric.require.min', // for fabric < 2.0.1
- 'fabric' : cdns.fabric + '/fabric.min', // for fabric >= 2.0.1
- 'tui-code-snippet' : cdns.tui + '/tui.code-snippet/latest/tui-code-snippet.min',
- 'tui-color-picker' : cdns.tui + '/tui-color-picker/latest/tui-color-picker.min',
- 'tui-image-editor' : cdns.tui + '/tui-image-editor/'+ver+'/tui-image-editor.min'
- }
- });
- require(['tui-image-editor'], function(ImageEditor) {
- loader.resolve(ImageEditor);
- });
- } else {
- fm.loadScript([
- cdns.fabric + '/fabric.min.js',
- cdns.tui + '/tui.code-snippet/latest/tui-code-snippet.min.js'
- ], function() {
- fm.loadScript([
- cdns.tui + '/tui-color-picker/latest/tui-color-picker.min.js'
- ], function() {
- fm.loadScript([
- cdns.tui + '/tui-image-editor/'+ver+'/tui-image-editor.min.js'
- ], function() {
- loader.resolve(window.tui.ImageEditor);
- }, {
- loadType: 'tag'
- });
- }, {
- loadType: 'tag'
- });
- }, {
- loadType: 'tag'
- });
- }
- loader.done(function(editor) {
- self.confObj.editor = editor;
- init(editor);
- });
- } else {
- init(self.confObj.editor);
- }
- return dfrd;
- },
- getContent : function(base) {
- var editor = this.editor,
- fm = editor.fm,
- $base = $(base),
- quality = $base.data('quality');
- if (editor.instance) {
- if ($base.data('mime') === 'image/jpeg') {
- quality = quality || fm.storage('jpgQuality') || fm.option('jpgQuality');
- quality = Math.max(0.1, Math.min(1, quality / 100));
- }
- return editor.instance.toDataURL({
- format: getExtention($base.data('mime'), fm, true),
- quality: quality
- });
- }
- },
- save : function(base) {
- var $base = $(base),
- quality = $base.data('quality'),
- hash = $base.data('hash'),
- file;
- this.instance.deactivateAll();
- if (typeof quality !== 'undefined') {
- this.fm.storage('jpgQuality', quality);
- }
- if (hash) {
- file = this.fm.file(hash);
- $base.data('mime', file.mime);
- }
- }
- },
- {
- // Photopea advanced image editor
- info : {
- id : 'photopea',
- name : 'Photopea',
- iconImg : 'img/editor-icons.png 0 -160',
- single: true,
- noContent: true,
- arrayBufferContent: true,
- openMaximized: true,
- // Disable file types that cannot be saved on Photopea.
- canMakeEmpty: ['image/jpeg', 'image/png', 'image/gif', 'image/svg+xml', 'image/x-ms-bmp', 'image/tiff', /*'image/x-adobe-dng',*/ 'image/webp', /*'image/x-xcf',*/ 'image/vnd.adobe.photoshop', 'application/pdf', 'image/x-portable-pixmap', 'image/x-sketch', 'image/x-icon', 'image/vnd-ms.dds', /*'application/x-msmetafile'*/],
- integrate: {
- title: 'Photopea',
- link: 'https://www.photopea.com/learn/'
- }
- },
- mimes : ['image/jpeg', 'image/png', 'image/gif', 'image/svg+xml', 'image/x-ms-bmp', 'image/tiff', 'image/x-adobe-dng', 'image/webp', 'image/x-xcf', 'image/vnd.adobe.photoshop', 'application/pdf', 'image/x-portable-pixmap', 'image/x-sketch', 'image/x-icon', 'image/vnd-ms.dds', 'application/x-msmetafile'],
- html : '<iframe style="width:100%;height:100%;border:none;"></iframe>',
- // setup on elFinder bootup
- setup : function(opts, fm) {
- if (fm.UA.IE || fm.UA.Mobile) {
- this.disabled = true;
- }
- },
- // Initialization of editing node (this: this editors HTML node)
- init : function(id, file, dum, fm) {
- var orig = 'https://www.photopea.com',
- ifm = $(this).hide()
- //.css('box-sizing', 'border-box')
- .on('load', function() {
- //spnr.remove();
- ifm.show();
- })
- .on('error', function() {
- spnr.remove();
- ifm.show();
- }),
- editor = this.editor,
- confObj = editor.confObj,
- spnr = $('<div class="elfinder-edit-spinner elfinder-edit-photopea"></div>')
- .html('<span class="elfinder-spinner-text">' + fm.i18n('nowLoading') + '</span><span class="elfinder-spinner"></span>')
- .appendTo(ifm.parent()),
- saveMimes = fm.arrayFlip(confObj.info.canMakeEmpty),
- getType = function(mime) {
- var ext = getExtention(mime, fm),
- extmime = ext2mime[ext];
- if (!confObj.mimesFlip[extmime]) {
- ext = '';
- } else if (ext === 'jpeg') {
- ext = 'jpg';
- }
- if (!ext || !saveMimes[extmime]) {
- ext = 'psd';
- extmime = ext2mime[ext];
- ifm.closest('.ui-dialog').trigger('changeType', {
- extention: ext,
- mime : extmime,
- keepEditor: true
- });
- }
- return ext;
- },
- mime = file.mime,
- liveMsg, type, quty;
-
- if (!confObj.mimesFlip) {
- confObj.mimesFlip = fm.arrayFlip(confObj.mimes, true);
- }
- if (!confObj.liveMsg) {
- confObj.liveMsg = function(ifm, spnr, file) {
- var wnd = ifm.get(0).contentWindow,
- phase = 0,
- data = null,
- dfdIni = $.Deferred().done(function() {
- spnr.remove();
- phase = 1;
- wnd.postMessage(data, orig);
- }),
- dfdGet;
- this.load = function() {
- return fm.getContents(file.hash, 'arraybuffer').done(function(d) {
- data = d;
- });
- };
- this.receive = function(e) {
- var ev = e.originalEvent,
- state;
- if (ev.origin === orig && ev.source === wnd) {
- if (ev.data === 'done') {
- if (phase === 0) {
- dfdIni.resolve();
- } else if (phase === 1) {
- phase = 2;
- ifm.trigger('contentsloaded');
- } else {
- if (dfdGet && dfdGet.state() === 'pending') {
- dfdGet.reject('errDataEmpty');
- }
- }
- } else if (ev.data === 'Save') {
- editor.doSave();
- } else {
- if (dfdGet && dfdGet.state() === 'pending') {
- if (typeof ev.data === 'object') {
- dfdGet.resolve('data:' + mime + ';base64,' + fm.arrayBufferToBase64(ev.data));
- } else {
- dfdGet.reject('errDataEmpty');
- }
- }
- }
- }
- };
- this.getContent = function() {
- var type, q;
- if (phase > 1) {
- dfdGet && dfdGet.state() === 'pending' && dfdGet.reject();
- dfdGet = null;
- dfdGet = $.Deferred();
- if (phase === 2) {
- phase = 3;
- dfdGet.resolve('data:' + mime + ';base64,' + fm.arrayBufferToBase64(data));
- data = null;
- return dfdGet;
- }
- if (ifm.data('mime')) {
- mime = ifm.data('mime');
- type = getType(mime);
- }
- if (q = ifm.data('quality')) {
- type += ':' + (q / 100);
- }
- wnd.postMessage('app.activeDocument.saveToOE("' + type + '")', orig);
- return dfdGet;
- }
- };
- };
- }
- ifm.parent().css('padding', 0);
- type = getType(file.mime);
- liveMsg = editor.liveMsg = new confObj.liveMsg(ifm, spnr, file);
- $(window).on('message.' + fm.namespace, liveMsg.receive);
- liveMsg.load().done(function() {
- var d = JSON.stringify({
- files : [],
- environment : {
- lang: fm.lang.replace(/_/g, '-'),
- customIO: {"save": "app.echoToOE(\"Save\");"}
- }
- });
- ifm.attr('src', orig + '/#' + encodeURI(d));
- }).fail(function(err) {
- err && fm.error(err);
- editor.initFail = true;
- });
- // jpeg quality controls
- if (file.mime === 'image/jpeg' || file.mime === 'image/webp') {
- ifm.data('quality', fm.storage('jpgQuality') || fm.option('jpgQuality'));
- quty = $('<input type="number" class="ui-corner-all elfinder-resize-quality elfinder-tabstop"/>')
- .attr('min', '1')
- .attr('max', '100')
- .attr('title', '1 - 100')
- .on('change', function() {
- var q = quty.val();
- ifm.data('quality', q);
- })
- .val(ifm.data('quality'));
- $('<div class="ui-dialog-buttonset elfinder-edit-extras elfinder-edit-extras-quality"></div>')
- .append(
- $('<span>').html(fm.i18n('quality') + ' : '), quty, $('<span></span>')
- )
- .prependTo(ifm.parent().next());
- }
- },
- load : function(base) {
- var dfd = $.Deferred(),
- self = this,
- fm = this.fm,
- $base = $(base);
- if (self.initFail) {
- dfd.reject();
- } else {
- $base.on('contentsloaded', function() {
- dfd.resolve(self.liveMsg);
- });
- }
- return dfd;
- },
- getContent : function() {
- return this.editor.liveMsg? this.editor.liveMsg.getContent() : void(0);
- },
- save : function(base, liveMsg) {
- var $base = $(base),
- quality = $base.data('quality'),
- hash = $base.data('hash'),
- file;
- if (typeof quality !== 'undefined') {
- this.fm.storage('jpgQuality', quality);
- }
- if (hash) {
- file = this.fm.file(hash);
- $base.data('mime', file.mime);
- } else {
- $base.removeData('mime');
- }
- },
- // On dialog closed
- close : function(base, liveMsg) {
- $(base).attr('src', '');
- liveMsg && $(window).off('message.' + this.fm.namespace, liveMsg.receive);
- }
- },
- {
- // Pixo is cross-platform image editor
- info : {
- id : 'pixo',
- name : 'Pixo Editor',
- iconImg : 'img/editor-icons.png 0 -208',
- dataScheme: true,
- schemeContent: true,
- single: true,
- canMakeEmpty: false,
- integrate: {
- title: 'Pixo Editor',
- link: 'https://pixoeditor.com/privacy-policy/'
- }
- },
- // MIME types to accept
- mimes : ['image/jpeg', 'image/png', 'image/gif', 'image/svg+xml', 'image/x-ms-bmp'],
- // HTML of this editor
- html : '<div class="elfinder-edit-imageeditor"><img/></div>',
- // called on initialization of elFinder cmd edit (this: this editor's config object)
- setup : function(opts, fm) {
- if (fm.UA.ltIE8 || !opts.extraOptions || !opts.extraOptions.pixo || !opts.extraOptions.pixo.apikey) {
- this.disabled = true;
- } else {
- this.editorOpts = opts.extraOptions.pixo;
- }
- },
- // Initialization of editing node (this: this editors HTML node)
- init : function(id, file, content, fm) {
- initImgTag.call(this, id, file, content, fm);
- },
- // Get data uri scheme (this: this editors HTML node)
- getContent : function() {
- return $(this).children('img:first').attr('src');
- },
- // Launch Pixo editor when dialog open
- load : function(base) {
- var self = this,
- fm = this.fm,
- $base = $(base),
- node = $base.children('img:first'),
- dialog = $base.closest('.ui-dialog'),
- elfNode = fm.getUI(),
- dfrd = $.Deferred(),
- container = $('#elfinder-pixo-container'),
- init = function(onload) {
- var opts;
-
- if (!container.length) {
- container = $('<div id="elfinder-pixo-container" class="ui-front"></div>').css({
- position: 'fixed',
- top: 0,
- right: 0,
- width: '100%',
- height: $(window).height(),
- overflow: 'hidden'
- }).hide().appendTo(elfNode.hasClass('elfinder-fullscreen')? elfNode : 'body');
- // bind switch fullscreen event
- elfNode.on('resize.'+fm.namespace, function(e, data) {
- e.preventDefault();
- e.stopPropagation();
- data && data.fullscreen && container.appendTo(data.fullscreen === 'on'? elfNode : 'body');
- });
- fm.bind('destroy', function() {
- editor && editor.cancelEditing();
- container.remove();
- });
- } else {
- // always moves to last
- container.appendTo(container.parent());
- }
- node.on('click', launch);
- // Constructor options
- opts = Object.assign({
- type: 'child',
- parent: container.get(0),
- output: {format: 'png'},
- onSave: function(arg) {
- // Check current file.hash, all callbacks are called on multiple instances
- var mime = arg.toBlob().type,
- ext = getExtention(mime, fm),
- draw = function(url) {
- node.one('load error', function() {
- node.data('loading') && node.data('loading')(true);
- })
- .attr('crossorigin', 'anonymous')
- .attr('src', url);
- },
- url = arg.toDataURL();
- node.data('loading')();
- delete base._canvas;
- if (node.data('ext') !== ext) {
- changeImageType(url, self.file.mime).done(function(res, cv) {
- if (cv) {
- base._canvas = canvas = cv;
- quty.trigger('change');
- qBase && qBase.show();
- }
- draw(res);
- }).fail(function() {
- dialog.trigger('changeType', {
- extention: ext,
- mime : mime
- });
- draw(url);
- });
- } else {
- draw(url);
- }
- },
- onClose: function() {
- dialog.removeClass(fm.res('class', 'preventback'));
- fm.toggleMaximize(container, false);
- container.hide();
- fm.toFront(dialog);
- }
- }, self.confObj.editorOpts);
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: base,
- editorObj: Pixo,
- instance: void(0),
- opts: opts
- });
- // make editor instance
- editor = new Pixo.Bridge(opts);
- dfrd.resolve(editor);
- $base.on('saveAsFail', launch);
- if (onload) {
- onload();
- }
- },
- launch = function() {
- dialog.addClass(fm.res('class', 'preventback'));
- fm.toggleMaximize(container, true);
- fm.toFront(container);
- container.show().data('curhash', self.file.hash);
- editor.edit(node.get(0));
- node.data('loading')(true);
- },
- qBase, quty, qutyTm, canvas, editor;
- node.data('loading')();
- // jpeg quality controls
- if (self.file.mime === 'image/jpeg') {
- quty = $('<input type="number" class="ui-corner-all elfinder-resize-quality elfinder-tabstop"/>')
- .attr('min', '1')
- .attr('max', '100')
- .attr('title', '1 - 100')
- .on('change', function() {
- var q = quty.val();
- qutyTm && cancelAnimationFrame(qutyTm);
- qutyTm = requestAnimationFrame(function() {
- if (canvas) {
- canvas.toBlob(function(blob) {
- blob && quty.next('span').text(' (' + fm.formatSize(blob.size) + ')');
- }, 'image/jpeg', Math.max(Math.min(q, 100), 1) / 100);
- }
- });
- })
- .val(fm.storage('jpgQuality') || fm.option('jpgQuality'));
- qBase = $('<div class="ui-dialog-buttonset elfinder-edit-extras elfinder-edit-extras-quality"></div>')
- .hide()
- .append(
- $('<span>').html(fm.i18n('quality') + ' : '), quty, $('<span></span>')
- )
- .prependTo($base.parent().next());
- $base.data('quty', quty);
- }
- // load script then init
- if (typeof Pixo === 'undefined') {
- fm.loadScript(['https://pixoeditor.com:8443/editor/scripts/bridge.m.js'], function() {
- init(launch);
- }, {loadType: 'tag'});
- } else {
- init();
- launch();
- }
- return dfrd;
- },
- // Convert content url to data uri scheme to save content
- save : function(base) {
- var self = this,
- $base = $(base),
- node = $base.children('img:first'),
- q;
- if (base._canvas) {
- if ($base.data('quty')) {
- q = $base.data('quty').val();
- q && this.fm.storage('jpgQuality', q);
- }
- node.attr('src', base._canvas.toDataURL(self.file.mime, q? Math.max(Math.min(q, 100), 1) / 100 : void(0)));
- } else if (node.attr('src').substr(0, 5) !== 'data:') {
- node.attr('src', imgBase64(node, this.file.mime));
- }
- },
- close : function(base, editor) {
- editor && editor.destroy();
- }
- },
- {
- // ACE Editor
- // called on initialization of elFinder cmd edit (this: this editor's config object)
- setup : function(opts, fm) {
- if (fm.UA.ltIE8 || !fm.options.cdns.ace) {
- this.disabled = true;
- }
- },
- // `mimes` is not set for support everything kind of text file
- info : {
- id : 'aceeditor',
- name : 'ACE Editor',
- iconImg : 'img/editor-icons.png 0 -96'
- },
- load : function(textarea) {
- var self = this,
- fm = this.fm,
- dfrd = $.Deferred(),
- cdn = fm.options.cdns.ace,
- start = function() {
- var editor, editorBase, mode,
- ta = $(textarea),
- taBase = ta.parent(),
- dialog = taBase.parent(),
- id = textarea.id + '_ace',
- ext = self.file.name.replace(/^.+\.([^.]+)|(.+)$/, '$1$2').toLowerCase(),
- // MIME/mode map
- mimeMode = {
- 'text/x-php' : 'php',
- 'application/x-php' : 'php',
- 'text/html' : 'html',
- 'application/xhtml+xml' : 'html',
- 'text/javascript' : 'javascript',
- 'application/javascript' : 'javascript',
- 'text/css' : 'css',
- 'text/x-c' : 'c_cpp',
- 'text/x-csrc' : 'c_cpp',
- 'text/x-chdr' : 'c_cpp',
- 'text/x-c++' : 'c_cpp',
- 'text/x-c++src' : 'c_cpp',
- 'text/x-c++hdr' : 'c_cpp',
- 'text/x-shellscript' : 'sh',
- 'application/x-csh' : 'sh',
- 'text/x-python' : 'python',
- 'text/x-java' : 'java',
- 'text/x-java-source' : 'java',
- 'text/x-ruby' : 'ruby',
- 'text/x-perl' : 'perl',
- 'application/x-perl' : 'perl',
- 'text/x-sql' : 'sql',
- 'text/xml' : 'xml',
- 'application/docbook+xml' : 'xml',
- 'application/xml' : 'xml'
- };
- // set base height
- taBase.height(taBase.height());
- // set basePath of ace
- ace.config.set('basePath', cdn);
- // Base node of Ace editor
- editorBase = $('<div id="'+id+'" style="width:100%; height:100%;"></div>').text(ta.val()).insertBefore(ta.hide());
- // Editor flag
- ta.data('ace', true);
- // Aceeditor instance
- editor = ace.edit(id);
- // Ace editor configure
- editor.$blockScrolling = Infinity;
- editor.setOptions({
- theme: 'ace/theme/monokai',
- fontSize: '14px',
- wrap: true,
- });
- ace.config.loadModule('ace/ext/modelist', function() {
- // detect mode
- mode = ace.require('ace/ext/modelist').getModeForPath('/' + self.file.name).name;
- if (mode === 'text') {
- if (mimeMode[self.file.mime]) {
- mode = mimeMode[self.file.mime];
- }
- }
- // show MIME:mode in title bar
- taBase.prev().children('.elfinder-dialog-title').append(' (' + self.file.mime + ' : ' + mode.split(/[\/\\]/).pop() + ')');
- editor.setOptions({
- mode: 'ace/mode/' + mode
- });
- if (dfrd.state() === 'resolved') {
- dialog.trigger('resize');
- }
- });
- ace.config.loadModule('ace/ext/language_tools', function() {
- ace.require('ace/ext/language_tools');
- editor.setOptions({
- enableBasicAutocompletion: true,
- enableSnippets: true,
- enableLiveAutocompletion: false
- });
- });
- ace.config.loadModule('ace/ext/settings_menu', function() {
- ace.require('ace/ext/settings_menu').init(editor);
- });
-
- // Short cuts
- editor.commands.addCommand({
- name : "saveFile",
- bindKey: {
- win : 'Ctrl-s',
- mac : 'Command-s'
- },
- exec: function(editor) {
- self.doSave();
- }
- });
- editor.commands.addCommand({
- name : "closeEditor",
- bindKey: {
- win : 'Ctrl-w|Ctrl-q',
- mac : 'Command-w|Command-q'
- },
- exec: function(editor) {
- self.doCancel();
- }
- });
- editor.resize();
- // TextArea button and Setting button
- $('<div class="ui-dialog-buttonset"></div>').css('float', 'left')
- .append(
- $('<button></button>').html(self.fm.i18n('TextArea'))
- .button()
- .on('click', function(){
- if (ta.data('ace')) {
- ta.removeData('ace');
- editorBase.hide();
- ta.val(editor.session.getValue()).show().trigger('focus');
- $(this).text('AceEditor');
- } else {
- ta.data('ace', true);
- editorBase.show();
- editor.setValue(ta.hide().val(), -1);
- editor.focus();
- $(this).html(self.fm.i18n('TextArea'));
- }
- })
- )
- .append(
- $('<button>Ace editor setting</button>')
- .button({
- icons: {
- primary: 'ui-icon-gear',
- secondary: 'ui-icon-triangle-1-e'
- },
- text: false
- })
- .on('click', function(){
- editor.showSettingsMenu();
- $('#ace_settingsmenu')
- .css('font-size', '80%')
- .find('div[contains="setOptions"]').hide().end()
- .parent().appendTo($('#elfinder'));
- })
- )
- .prependTo(taBase.next());
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: textarea,
- editorObj: ace,
- instance: editor,
- opts: {}
- });
-
- //dialog.trigger('resize');
- dfrd.resolve(editor);
- };
- // check ace & start
- if (!self.confObj.loader) {
- self.confObj.loader = $.Deferred();
- self.fm.loadScript([ cdn+'/ace.js' ], function() {
- self.confObj.loader.resolve();
- }, void 0, {obj: window, name: 'ace'});
- }
- self.confObj.loader.done(start);
- return dfrd;
- },
- close : function(textarea, instance) {
- instance && instance.destroy();
- },
- save : function(textarea, instance) {
- instance && $(textarea).data('ace') && (textarea.value = instance.session.getValue());
- },
- focus : function(textarea, instance) {
- instance && $(textarea).data('ace') && instance.focus();
- },
- resize : function(textarea, instance, e, data) {
- instance && instance.resize();
- }
- },
- {
- // CodeMirror
- // called on initialization of elFinder cmd edit (this: this editor's config object)
- setup : function(opts, fm) {
- if (fm.UA.ltIE10 || !fm.options.cdns.codemirror) {
- this.disabled = true;
- }
- },
- // `mimes` is not set for support everything kind of text file
- info : {
- id : 'codemirror',
- name : 'CodeMirror',
- iconImg : 'img/editor-icons.png 0 -176'
- },
- load : function(textarea) {
- var fm = this.fm,
- cmUrl = fm.convAbsUrl(fm.options.cdns.codemirror),
- dfrd = $.Deferred(),
- self = this,
- start = function(CodeMirror) {
- var ta = $(textarea),
- base = ta.parent(),
- editor, editorBase, opts;
-
- // set base height
- base.height(base.height());
-
- // CodeMirror configure options
- opts = {
- lineNumbers: true,
- lineWrapping: true,
- extraKeys : {
- 'Ctrl-S': function() { self.doSave(); },
- 'Ctrl-Q': function() { self.doCancel(); },
- 'Ctrl-W': function() { self.doCancel(); }
- }
- };
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: textarea,
- editorObj: CodeMirror,
- instance: void(0),
- opts: opts
- });
- // CodeMirror configure
- editor = CodeMirror.fromTextArea(textarea, opts);
-
- // return editor instance
- dfrd.resolve(editor);
-
- // Auto mode set
- var info, m, mode, spec;
- if (! info) {
- info = CodeMirror.findModeByMIME(self.file.mime);
- }
- if (! info && (m = self.file.name.match(/.+\.([^.]+)$/))) {
- info = CodeMirror.findModeByExtension(m[1]);
- }
- if (info) {
- CodeMirror.modeURL = useRequire? 'codemirror/mode/%N/%N.min' : cmUrl + '/mode/%N/%N.min.js';
- mode = info.mode;
- spec = info.mime;
- editor.setOption('mode', spec);
- CodeMirror.autoLoadMode(editor, mode);
- // show MIME:mode in title bar
- base.prev().children('.elfinder-dialog-title').append(' (' + spec + (mode != 'null'? ' : ' + mode : '') + ')');
- }
-
- // editor base node
- editorBase = $(editor.getWrapperElement()).css({
- // fix CSS conflict to SimpleMDE
- padding: 0,
- border: 'none'
- });
- ta.data('cm', true);
-
- // fit height to base
- editorBase.height('100%');
-
- // TextArea button and Setting button
- $('<div class="ui-dialog-buttonset"></div>').css('float', 'left')
- .append(
- $('<button></button>').html(self.fm.i18n('TextArea'))
- .button()
- .on('click', function(){
- if (ta.data('cm')) {
- ta.removeData('cm');
- editorBase.hide();
- ta.val(editor.getValue()).show().trigger('focus');
- $(this).text('CodeMirror');
- } else {
- ta.data('cm', true);
- editorBase.show();
- editor.setValue(ta.hide().val());
- editor.refresh();
- editor.focus();
- $(this).html(self.fm.i18n('TextArea'));
- }
- })
- )
- .prependTo(base.next());
- };
- // load script then start
- if (!self.confObj.loader) {
- self.confObj.loader = $.Deferred();
- if (useRequire) {
- require.config({
- packages: [{
- name: 'codemirror',
- location: cmUrl,
- main: 'codemirror.min'
- }],
- map: {
- 'codemirror': {
- 'codemirror/lib/codemirror': 'codemirror'
- }
- }
- });
- require([
- 'codemirror',
- 'codemirror/addon/mode/loadmode.min',
- 'codemirror/mode/meta.min'
- ], function(CodeMirror) {
- self.confObj.loader.resolve(CodeMirror);
- });
- } else {
- self.fm.loadScript([
- cmUrl + '/codemirror.min.js'
- ], function() {
- self.fm.loadScript([
- cmUrl + '/addon/mode/loadmode.min.js',
- cmUrl + '/mode/meta.min.js'
- ], function() {
- self.confObj.loader.resolve(CodeMirror);
- });
- }, {loadType: 'tag'});
- }
- self.fm.loadCss(cmUrl + '/codemirror.css');
- }
- self.confObj.loader.done(start);
- return dfrd;
- },
- close : function(textarea, instance) {
- instance && instance.toTextArea();
- },
- save : function(textarea, instance) {
- instance && $(textarea).data('cm') && (textarea.value = instance.getValue());
- },
- focus : function(textarea, instance) {
- instance && $(textarea).data('cm') && instance.focus();
- },
- resize : function(textarea, instance, e, data) {
- instance && instance.refresh();
- }
- },
- {
- // SimpleMDE
- // called on initialization of elFinder cmd edit (this: this editor's config object)
- setup : function(opts, fm) {
- if (fm.UA.ltIE10 || !fm.options.cdns.simplemde) {
- this.disabled = true;
- }
- },
- info : {
- id : 'simplemde',
- name : 'SimpleMDE',
- iconImg : 'img/editor-icons.png 0 -80'
- },
- exts : ['md'],
- load : function(textarea) {
- var self = this,
- fm = this.fm,
- base = $(textarea).parent(),
- dfrd = $.Deferred(),
- cdn = fm.options.cdns.simplemde,
- start = function(SimpleMDE) {
- var h = base.height(),
- delta = base.outerHeight(true) - h + 14,
- editor, editorBase, opts;
-
- // fit height function
- textarea._setHeight = function(height) {
- var h = height || base.height(),
- ctrH = 0,
- areaH;
- base.children('.editor-toolbar,.editor-statusbar').each(function() {
- ctrH += $(this).outerHeight(true);
- });
- areaH = h - ctrH - delta;
- editorBase.height(areaH);
- editor.codemirror.refresh();
- return areaH;
- };
-
- // set base height
- base.height(h);
-
- opts = {
- element: textarea,
- autofocus: true
- };
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: textarea,
- editorObj: SimpleMDE,
- instance: void(0),
- opts: opts
- });
- // make editor
- editor = new SimpleMDE(opts);
- dfrd.resolve(editor);
-
- // editor base node
- editorBase = $(editor.codemirror.getWrapperElement());
-
- // fit height to base
- editorBase.css('min-height', '50px')
- .children('.CodeMirror-scroll').css('min-height', '50px');
- textarea._setHeight(h);
- };
- // check SimpleMDE & start
- if (!self.confObj.loader) {
- self.confObj.loader = $.Deferred();
- self.fm.loadCss(cdn+'/simplemde.min.css');
- if (useRequire) {
- require([
- cdn+'/simplemde.min.js'
- ], function(SimpleMDE) {
- self.confObj.loader.resolve(SimpleMDE);
- });
- } else {
- self.fm.loadScript([cdn+'/simplemde.min.js'], function() {
- self.confObj.loader.resolve(SimpleMDE);
- }, {loadType: 'tag'});
- }
- }
- self.confObj.loader.done(start);
- return dfrd;
- },
- close : function(textarea, instance) {
- instance && instance.toTextArea();
- instance = null;
- },
- save : function(textarea, instance) {
- instance && (textarea.value = instance.value());
- },
- focus : function(textarea, instance) {
- instance && instance.codemirror.focus();
- },
- resize : function(textarea, instance, e, data) {
- instance && textarea._setHeight();
- }
- },
- {
- // CKEditor for html file
- info : {
- id : 'ckeditor',
- name : 'CKEditor',
- iconImg : 'img/editor-icons.png 0 0'
- },
- exts : ['htm', 'html', 'xhtml'],
- setup : function(opts, fm) {
- var confObj = this;
- if (!fm.options.cdns.ckeditor) {
- confObj.disabled = true;
- } else {
- confObj.ckeOpts = {};
- if (opts.extraOptions) {
- confObj.ckeOpts = Object.assign({}, opts.extraOptions.ckeditor || {});
- if (opts.extraOptions.managerUrl) {
- confObj.managerUrl = opts.extraOptions.managerUrl;
- }
- }
- }
- },
- load : function(textarea) {
- var self = this,
- fm = this.fm,
- dfrd = $.Deferred(),
- init = function() {
- var base = $(textarea).parent(),
- dlg = base.closest('.elfinder-dialog'),
- h = base.height(),
- reg = /([&?]getfile=)[^&]+/,
- loc = self.confObj.managerUrl || window.location.href.replace(/#.*$/, ''),
- name = 'ckeditor',
- opts;
-
- // make manager location
- if (reg.test(loc)) {
- loc = loc.replace(reg, '$1' + name);
- } else {
- loc += '?getfile=' + name;
- }
- // set base height
- base.height(h);
- // CKEditor configure options
- opts = {
- startupFocus : true,
- fullPage: true,
- allowedContent: true,
- filebrowserBrowseUrl : loc,
- toolbarCanCollapse: true,
- toolbarStartupExpanded: !fm.UA.Mobile,
- removePlugins: 'resize',
- extraPlugins: 'colorbutton,justify,docprops',
- on: {
- 'instanceReady' : function(e) {
- var editor = e.editor;
- editor.resize('100%', h);
- // re-build on dom move
- dlg.one('beforedommove.'+fm.namespace, function() {
- editor.destroy();
- }).one('dommove.'+fm.namespace, function() {
- self.load(textarea).done(function(editor) {
- self.instance = editor;
- });
- });
- // return editor instance
- dfrd.resolve(e.editor);
- }
- }
- };
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: textarea,
- editorObj: CKEDITOR,
- instance: void(0),
- opts: opts
- });
- // CKEditor configure
- CKEDITOR.replace(textarea.id, Object.assign(opts, self.confObj.ckeOpts));
- CKEDITOR.on('dialogDefinition', function(e) {
- var dlg = e.data.definition.dialog;
- dlg.on('show', function(e) {
- fm.getUI().append($('.cke_dialog_background_cover')).append(this.getElement().$);
- });
- dlg.on('hide', function(e) {
- $('body:first').append($('.cke_dialog_background_cover')).append(this.getElement().$);
- });
- });
- };
- if (!self.confObj.loader) {
- self.confObj.loader = $.Deferred();
- window.CKEDITOR_BASEPATH = fm.options.cdns.ckeditor + '/';
- $.getScript(fm.options.cdns.ckeditor + '/ckeditor.js', function() {
- self.confObj.loader.resolve();
- });
- }
- self.confObj.loader.done(init);
- return dfrd;
- },
- close : function(textarea, instance) {
- instance && instance.destroy();
- },
- save : function(textarea, instance) {
- instance && (textarea.value = instance.getData());
- },
- focus : function(textarea, instance) {
- instance && instance.focus();
- },
- resize : function(textarea, instance, e, data) {
- var self;
- if (instance) {
- if (instance.status === 'ready') {
- instance.resize('100%', $(textarea).parent().height());
- }
- }
- }
- },
- {
- // CKEditor5 balloon mode for html file
- info : {
- id : 'ckeditor5',
- name : 'CKEditor5',
- iconImg : 'img/editor-icons.png 0 -16'
- },
- exts : ['htm', 'html', 'xhtml'],
- html : '<div class="edit-editor-ckeditor5"></div>',
- setup : function(opts, fm) {
- var confObj = this;
- // check cdn and ES6 support
- if (!fm.options.cdns.ckeditor5 || typeof window.Symbol !== 'function' || typeof Symbol() !== 'symbol') {
- confObj.disabled = true;
- } else {
- confObj.ckeOpts = {};
- if (opts.extraOptions) {
- // @deprecated option extraOptions.ckeditor5Mode
- if (opts.extraOptions.ckeditor5Mode) {
- confObj.ckeditor5Mode = opts.extraOptions.ckeditor5Mode;
- }
- confObj.ckeOpts = Object.assign({}, opts.extraOptions.ckeditor5 || {});
- if (confObj.ckeOpts.mode) {
- confObj.ckeditor5Mode = confObj.ckeOpts.mode;
- delete confObj.ckeOpts.mode;
- }
- if (opts.extraOptions.managerUrl) {
- confObj.managerUrl = opts.extraOptions.managerUrl;
- }
- }
- }
- fm.bind('destroy', function() {
- confObj.editor = null;
- });
- },
- // Prepare on before show dialog
- prepare : function(base, dialogOpts, file) {
- $(base).height(base.editor.fm.getUI().height() - 100);
- },
- init : function(id, file, data, fm) {
- var m = data.match(/^([\s\S]*<body[^>]*>)([\s\S]+)(<\/body>[\s\S]*)$/i),
- header = '',
- body = '',
- footer ='';
- this.css({
- width: '100%',
- height: '100%',
- 'box-sizing': 'border-box'
- });
- if (m) {
- header = m[1];
- body = m[2];
- footer = m[3];
- } else {
- body = data;
- }
- this.data('data', {
- header: header,
- body: body,
- footer: footer
- });
- this._setupSelEncoding(data);
- },
- load : function(editnode) {
- var self = this,
- fm = this.fm,
- dfrd = $.Deferred(),
- mode = self.confObj.ckeditor5Mode || 'decoupled-document',
- lang = (function() {
- var l = fm.lang.toLowerCase().replace('_', '-');
- if (l.substr(0, 2) === 'zh' && l !== 'zh-cn') {
- l = 'zh';
- }
- return l;
- })(),
- init = function(cEditor) {
- var base = $(editnode).parent(),
- opts;
-
- // set base height
- base.height(fm.getUI().height() - 100);
- // CKEditor5 configure options
- opts = Object.assign({
- toolbar: ["heading", "|", "fontSize", "fontFamily", "|", "bold", "italic", "underline", "strikethrough", "highlight", "|", "alignment", "|", "numberedList", "bulletedList", "blockQuote", "indent", "outdent", "|", "ckfinder", "link", "imageUpload", "insertTable", "mediaEmbed", "|", "undo", "redo"],
- language: lang
- }, self.confObj.ckeOpts);
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: editnode,
- editorObj: cEditor,
- instance: void(0),
- opts: opts
- });
- cEditor
- .create(editnode, opts)
- .then(function(editor) {
- var ckf = editor.commands.get('ckfinder'),
- fileRepo = editor.plugins.get('FileRepository'),
- prevVars = {}, isImage, insertImages;
- if (editor.ui.view.toolbar && (mode === 'classic' || mode === 'decoupled-document')) {
- $(editnode).closest('.elfinder-dialog').children('.ui-widget-header').append($(editor.ui.view.toolbar.element).css({marginRight:'-1em',marginLeft:'-1em'}));
- }
- if (mode === 'classic') {
- $(editnode).closest('.elfinder-edit-editor').css('overflow', 'auto');
- }
- // Set up this elFinder instead of CKFinder
- if (ckf) {
- isImage = function(f) {
- return f && f.mime.match(/^image\//i);
- };
- insertImages = function(urls) {
- var imgCmd = editor.commands.get('imageUpload');
- if (!imgCmd.isEnabled) {
- var ntf = editor.plugins.get('Notification'),
- i18 = editor.locale.t;
- ntf.showWarning(i18('Could not insert image at the current position.'), {
- title: i18('Inserting image failed'),
- namespace: 'ckfinder'
- });
- return;
- }
- editor.execute('imageInsert', { source: urls });
- };
- // Take over ckfinder execute()
- ckf.execute = function() {
- var dlg = base.closest('.elfinder-dialog'),
- gf = fm.getCommand('getfile'),
- rever = function() {
- if (prevVars.hasVar) {
- dlg.off('resize close', rever);
- gf.callback = prevVars.callback;
- gf.options.folders = prevVars.folders;
- gf.options.multiple = prevVars.multi;
- fm.commandMap.open = prevVars.open;
- prevVars.hasVar = false;
- }
- };
- dlg.trigger('togleminimize').one('resize close', rever);
- prevVars.callback = gf.callback;
- prevVars.folders = gf.options.folders;
- prevVars.multi = gf.options.multiple;
- prevVars.open = fm.commandMap.open;
- prevVars.hasVar = true;
- gf.callback = function(files) {
- var imgs = [];
- if (files.length === 1 && files[0].mime === 'directory') {
- fm.one('open', function() {
- fm.commandMap.open = 'getfile';
- }).getCommand('open').exec(files[0].hash);
- return;
- }
- fm.getUI('cwd').trigger('unselectall');
- $.each(files, function(i, f) {
- if (isImage(f)) {
- imgs.push(fm.convAbsUrl(f.url));
- } else {
- editor.execute('link', fm.convAbsUrl(f.url));
- }
- });
- if (imgs.length) {
- insertImages(imgs);
- }
- dlg.trigger('togleminimize');
- };
- gf.options.folders = true;
- gf.options.multiple = true;
- fm.commandMap.open = 'getfile';
- fm.toast({
- mode: 'info',
- msg: fm.i18n('dblclickToSelect')
- });
- };
- }
- // Set up image uploader
- fileRepo.createUploadAdapter = function(loader) {
- return new uploder(loader);
- };
- editor.setData($(editnode).data('data').body);
- // move .ck-body to elFinder node for fullscreen mode
- fm.getUI().append($('body > div.ck-body'));
- $('div.ck-balloon-panel').css({
- 'z-index': fm.getMaximizeCss().zIndex + 1
- });
- dfrd.resolve(editor);
- /*fm.log({
- defaultConfig: cEditor.defaultConfig,
- plugins: cEditor.builtinPlugins.map(function(p) { return p.pluginName; }),
- toolbars: Array.from(editor.ui.componentFactory.names())
- });*/
- })
- ['catch'](function(error) { // ['cache'] instead .cache for fix error on ie8
- fm.error(error);
- });
- },
- uploder = function(loader) {
- var upload = function(file, resolve, reject) {
- fm.exec('upload', {files: [file]}, void(0), fm.cwd().hash)
- .done(function(data){
- if (data.added && data.added.length) {
- fm.url(data.added[0].hash, { async: true }).done(function(url) {
- resolve({
- 'default': fm.convAbsUrl(url)
- });
- }).fail(function() {
- reject('errFileNotFound');
- });
- } else {
- reject(fm.i18n(data.error? data.error : 'errUpload'));
- }
- })
- .fail(function(err) {
- var error = fm.parseError(err);
- reject(fm.i18n(error? (error === 'userabort'? 'errAbort' : error) : 'errUploadNoFiles'));
- })
- .progress(function(data) {
- loader.uploadTotal = data.total;
- loader.uploaded = data.progress;
- });
- };
- this.upload = function() {
- return new Promise(function(resolve, reject) {
- if (loader.file instanceof Promise || (loader.file && typeof loader.file.then === 'function')) {
- loader.file.then(function(file) {
- upload(file, resolve, reject);
- });
- } else {
- upload(loader.file, resolve, reject);
- }
- });
- };
- this.abort = function() {
- fm.getUI().trigger('uploadabort');
- };
- }, loader;
- if (!self.confObj.editor) {
- loader = $.Deferred();
- self.fm.loadScript([
- fm.options.cdns.ckeditor5 + '/' + mode + '/ckeditor.js'
- ], function(editor) {
- if (!editor) {
- editor = window.BalloonEditor || window.InlineEditor || window.ClassicEditor || window.DecoupledEditor;
- }
- if (fm.lang !== 'en') {
- self.fm.loadScript([
- fm.options.cdns.ckeditor5 + '/' + mode + '/translations/' + lang + '.js'
- ], function(obj) {
- loader.resolve(editor);
- }, {
- tryRequire: true,
- loadType: 'tag',
- error: function(obj) {
- lang = 'en';
- loader.resolve(editor);
- }
- });
- } else {
- loader.resolve(editor);
- }
- }, {
- tryRequire: true,
- loadType: 'tag'
- });
- loader.done(function(editor) {
- self.confObj.editor = editor;
- init(editor);
- });
- } else {
- init(self.confObj.editor);
- }
- return dfrd;
- },
- getContent : function() {
- var data = $(this).data('data');
- return data.header + data.body + data.footer;
- },
- close : function(editnode, instance) {
- instance && instance.destroy();
- },
- save : function(editnode, instance) {
- var elm = $(editnode),
- data = elm.data('data');
- if (instance) {
- data.body = instance.getData();
- elm.data('data', data);
- }
- },
- focus : function(editnode, instance) {
- $(editnode).trigger('focus');
- }
- },
- {
- // TinyMCE for html file
- info : {
- id : 'tinymce',
- name : 'TinyMCE',
- iconImg : 'img/editor-icons.png 0 -64'
- },
- exts : ['htm', 'html', 'xhtml'],
- setup : function(opts, fm) {
- var confObj = this;
- if (!fm.options.cdns.tinymce) {
- confObj.disabled = true;
- } else {
- confObj.mceOpts = {};
- if (opts.extraOptions) {
- confObj.uploadOpts = Object.assign({}, opts.extraOptions.uploadOpts || {});
- confObj.mceOpts = Object.assign({}, opts.extraOptions.tinymce || {});
- } else {
- confObj.uploadOpts = {};
- }
- }
- },
- load : function(textarea) {
- var self = this,
- fm = this.fm,
- dfrd = $.Deferred(),
- init = function() {
- var base = $(textarea).show().parent(),
- dlg = base.closest('.elfinder-dialog'),
- h = base.height(),
- delta = base.outerHeight(true) - h,
- // hide MCE dialog and modal block
- hideMceDlg = function() {
- var mceW;
- if (tinymce.activeEditor.windowManager.windows) {
- mceW = tinymce.activeEditor.windowManager.windows[0];
- mceDlg = $(mceW? mceW.getEl() : void(0)).hide();
- mceCv = $('#mce-modal-block').hide();
- } else {
- mceDlg = $('.tox-dialog-wrap').hide();
- }
- },
- // Show MCE dialog and modal block
- showMceDlg = function() {
- mceCv && mceCv.show();
- mceDlg && mceDlg.show();
- },
- tVer = tinymce.majorVersion,
- opts, mceDlg, mceCv;
- // set base height
- base.height(h);
- // fit height function
- textarea._setHeight = function(height) {
- if (tVer < 5) {
- var base = $(this).parent(),
- h = height || base.innerHeight(),
- ctrH = 0,
- areaH;
- base.find('.mce-container-body:first').children('.mce-top-part,.mce-statusbar').each(function() {
- ctrH += $(this).outerHeight(true);
- });
- areaH = h - ctrH - delta;
- base.find('.mce-edit-area iframe:first').height(areaH);
- }
- };
- // TinyMCE configure options
- opts = {
- selector: '#' + textarea.id,
- resize: false,
- plugins: 'print preview fullpage searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists wordcount imagetools textpattern help',
- toolbar: 'formatselect | bold italic strikethrough forecolor backcolor | link image media | alignleft aligncenter alignright alignjustify | numlist bullist outdent indent | removeformat',
- image_advtab: true,
- init_instance_callback : function(editor) {
- // fit height on init
- textarea._setHeight(h);
- // re-build on dom move
- dlg.one('beforedommove.'+fm.namespace, function() {
- tinymce.execCommand('mceRemoveEditor', false, textarea.id);
- }).one('dommove.'+fm.namespace, function() {
- self.load(textarea).done(function(editor) {
- self.instance = editor;
- });
- });
- // return editor instance
- dfrd.resolve(editor);
- },
- file_picker_callback : function (callback, value, meta) {
- var gf = fm.getCommand('getfile'),
- revar = function() {
- if (prevVars.hasVar) {
- gf.callback = prevVars.callback;
- gf.options.folders = prevVars.folders;
- gf.options.multiple = prevVars.multi;
- fm.commandMap.open = prevVars.open;
- prevVars.hasVar = false;
- }
- dlg.off('resize close', revar);
- showMceDlg();
- },
- prevVars = {};
- prevVars.callback = gf.callback;
- prevVars.folders = gf.options.folders;
- prevVars.multi = gf.options.multiple;
- prevVars.open = fm.commandMap.open;
- prevVars.hasVar = true;
- gf.callback = function(file) {
- var url, info;
- if (file.mime === 'directory') {
- fm.one('open', function() {
- fm.commandMap.open = 'getfile';
- }).getCommand('open').exec(file.hash);
- return;
- }
- // URL normalization
- url = fm.convAbsUrl(file.url);
-
- // Make file info
- info = file.name + ' (' + fm.formatSize(file.size) + ')';
- // Provide file and text for the link dialog
- if (meta.filetype == 'file') {
- callback(url, {text: info, title: info});
- }
- // Provide image and alt text for the image dialog
- if (meta.filetype == 'image') {
- callback(url, {alt: info});
- }
- // Provide alternative source and posted for the media dialog
- if (meta.filetype == 'media') {
- callback(url);
- }
- dlg.trigger('togleminimize');
- };
- gf.options.folders = true;
- gf.options.multiple = false;
- fm.commandMap.open = 'getfile';
-
- hideMceDlg();
- dlg.trigger('togleminimize').one('resize close', revar);
- fm.toast({
- mode: 'info',
- msg: fm.i18n('dblclickToSelect')
- });
- return false;
- },
- images_upload_handler : function (blobInfo, success, failure) {
- var file = blobInfo.blob(),
- err = function(e) {
- var dlg = e.data.dialog || {};
- if (dlg.hasClass('elfinder-dialog-error') || dlg.hasClass('elfinder-confirm-upload')) {
- hideMceDlg();
- dlg.trigger('togleminimize').one('resize close', revert);
- fm.unbind('dialogopened', err);
- }
- },
- revert = function() {
- dlg.off('resize close', revert);
- showMceDlg();
- },
- clipdata = true;
- // check file object
- if (file.name) {
- // file blob of client side file object
- clipdata = void(0);
- }
- fm.bind('dialogopened', err).exec('upload', Object.assign({
- files: [file],
- clipdata: clipdata // to get unique name on connector
- }, self.confObj.uploadOpts), void(0), fm.cwd().hash).done(function(data) {
- if (data.added && data.added.length) {
- fm.url(data.added[0].hash, { async: true }).done(function(url) {
- showMceDlg();
- success(fm.convAbsUrl(url));
- }).fail(function() {
- failure(fm.i18n('errFileNotFound'));
- });
- } else {
- failure(fm.i18n(data.error? data.error : 'errUpload'));
- }
- }).fail(function(err) {
- var error = fm.parseError(err);
- if (error) {
- if (error === 'errUnknownCmd') {
- error = 'errPerm';
- } else if (error === 'userabort') {
- error = 'errAbort';
- }
- }
- failure(fm.i18n(error? error : 'errUploadNoFiles'));
- });
- }
- };
- // TinyMCE 5 supports "height: 100%"
- if (tVer >= 5) {
- opts.height = '100%';
- }
- // trigger event 'editEditorPrepare'
- self.trigger('Prepare', {
- node: textarea,
- editorObj: tinymce,
- instance: void(0),
- opts: opts
- });
- // TinyMCE configure
- tinymce.init(Object.assign(opts, self.confObj.mceOpts));
- };
-
- if (!self.confObj.loader) {
- self.confObj.loader = $.Deferred();
- self.fm.loadScript([fm.options.cdns.tinymce + (fm.options.cdns.tinymce.match(/\.js/)? '' : '/tinymce.min.js')], function() {
- self.confObj.loader.resolve();
- }, {
- loadType: 'tag'
- });
- }
- self.confObj.loader.done(init);
- return dfrd;
- },
- close : function(textarea, instance) {
- instance && tinymce.execCommand('mceRemoveEditor', false, textarea.id);
- },
- save : function(textarea, instance) {
- instance && instance.save();
- },
- focus : function(textarea, instance) {
- instance && instance.focus();
- },
- resize : function(textarea, instance, e, data) {
- // fit height to base node on dialog resize
- instance && textarea._setHeight();
- }
- },
- {
- info : {
- id : 'zohoeditor',
- name : 'Zoho Editor',
- iconImg : 'img/editor-icons.png 0 -32',
- cmdCheck : 'ZohoOffice',
- preventGet: true,
- hideButtons: true,
- syncInterval : 15000,
- canMakeEmpty: true,
- integrate: {
- title: 'Zoho Office API',
- link: 'https://www.zoho.com/officeapi/'
- }
- },
- mimes : [
- 'application/msword',
- 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
- //'application/pdf',
- 'application/vnd.oasis.opendocument.text',
- 'application/rtf',
- 'text/html',
- 'application/vnd.ms-excel',
- 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
- 'application/vnd.oasis.opendocument.spreadsheet',
- 'application/vnd.sun.xml.calc',
- 'text/csv',
- 'text/tab-separated-values',
- 'application/vnd.ms-powerpoint',
- 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
- 'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
- 'application/vnd.oasis.opendocument.presentation',
- 'application/vnd.sun.xml.impress'
- ],
- html : '<iframe style="width:100%;max-height:100%;border:none;"></iframe>',
- // setup on elFinder bootup
- setup : function(opts, fm) {
- if (fm.UA.Mobile || fm.UA.ltIE8) {
- this.disabled = true;
- }
- },
- // Prepare on before show dialog
- prepare : function(base, dialogOpts, file) {
- var elfNode = base.editor.fm.getUI();
- $(base).height(elfNode.height());
- dialogOpts.width = Math.max(dialogOpts.width || 0, elfNode.width() * 0.8);
- },
- // Initialization of editing node (this: this editors HTML node)
- init : function(id, file, dum, fm) {
- var ta = this,
- ifm = $(this).hide(),
- uiToast = fm.getUI('toast'),
- spnr = $('<div class="elfinder-edit-spinner elfinder-edit-zohoeditor"></div>')
- .html('<span class="elfinder-spinner-text">' + fm.i18n('nowLoading') + '</span><span class="elfinder-spinner"></span>')
- .appendTo(ifm.parent()),
- cdata = function() {
- var data = '';
- $.each(fm.customData, function(key, val) {
- data += '&' + encodeURIComponent(key) + '=' + encodeURIComponent(val);
- });
- return data;
- };
-
- $(ta).data('xhr', fm.request({
- data: {
- cmd: 'editor',
- name: ta.editor.confObj.info.cmdCheck,
- method: 'init',
- 'args[target]': file.hash,
- 'args[lang]' : fm.lang,
- 'args[cdata]' : cdata()
- },
- preventDefault : true
- }).done(function(data) {
- var opts;
- if (data.zohourl) {
- opts = {
- css: {
- height: '100%'
- }
- };
- // trigger event 'editEditorPrepare'
- ta.editor.trigger('Prepare', {
- node: ta,
- editorObj: void(0),
- instance: ifm,
- opts: opts
- });
- ifm.attr('src', data.zohourl).show().css(opts.css);
- if (data.warning) {
- uiToast.appendTo(ta.closest('.ui-dialog'));
- fm.toast({
- msg: fm.i18n(data.warning),
- mode: 'warning',
- timeOut: 0,
- onHidden: function() {
- uiToast.children().length === 1 && uiToast.appendTo(fm.getUI());
- },
- button: {
- text: 'btnYes'
- }
- });
- }
- } else {
- data.error && fm.error(data.error);
- ta.elfinderdialog('destroy');
- }
- }).fail(function(error) {
- error && fm.error(error);
- ta.elfinderdialog('destroy');
- }).always(function() {
- spnr.remove();
- }));
- },
- load : function() {},
- getContent : function() {},
- save : function() {},
- // Before dialog close
- beforeclose : iframeClose,
- // On dialog closed
- close : function(ta) {
- var fm = this.fm,
- xhr = $(ta).data('xhr');
- if (xhr.state() === 'pending') {
- xhr.reject();
- }
- }
- },
- {
- // Zip Archive with FlySystem
- info : {
- id : 'ziparchive',
- name : 'btnMount',
- iconImg : 'img/toolbar.png 0 -416',
- cmdCheck : 'ZipArchive',
- edit : function(file, editor) {
- var fm = this,
- dfrd = $.Deferred();
- fm.request({
- data:{
- cmd: 'netmount',
- protocol: 'ziparchive',
- host: file.hash,
- path: file.phash
- },
- preventFail: true,
- notify : {type : 'netmount', cnt : 1, hideCnt : true}
- }).done(function(data) {
- var pdir;
- if (data.added && data.added.length) {
- if (data.added[0].phash) {
- if (pdir = fm.file(data.added[0].phash)) {
- if (! pdir.dirs) {
- pdir.dirs = 1;
- fm.change({ changed: [ pdir ] });
- }
- }
- }
- fm.one('netmountdone', function() {
- fm.exec('open', data.added[0].hash);
- fm.one('opendone', function() {
- data.toast && fm.toast(data.toast);
- });
- });
- }
- dfrd.resolve();
- })
- .fail(function(error) {
- dfrd.reject(error);
- });
- return dfrd;
- }
- },
- mimes : ['application/zip'],
- load : function() {},
- save : function(){}
- },
- {
- // Simple Text (basic textarea editor)
- info : {
- id : 'textarea',
- name : 'TextArea',
- useTextAreaEvent : true
- },
- load : function(textarea) {
- // trigger event 'editEditorPrepare'
- this.trigger('Prepare', {
- node: textarea,
- editorObj: void(0),
- instance: void(0),
- opts: {}
- });
- textarea.setSelectionRange && textarea.setSelectionRange(0, 0);
- $(textarea).trigger('focus').show();
- },
- save : function(){}
- },
- {
- // File converter with online-convert.com
- info : {
- id : 'onlineconvert',
- name : 'Online Convert',
- iconImg : 'img/editor-icons.png 0 -144',
- cmdCheck : 'OnlineConvert',
- preventGet: true,
- hideButtons: true,
- single: true,
- converter: true,
- canMakeEmpty: false,
- integrate: {
- title: 'ONLINE-CONVERT.COM',
- link: 'https://online-convert.com'
- }
- },
- mimes : ['*'],
- html : '<div style="width:100%;max-height:100%;"></div>',
- // setup on elFinder bootup
- setup : function(opts, fm) {
- var mOpts = opts.extraOptions.onlineConvert || {maxSize:100,showLink:true};
- if (mOpts.maxSize) {
- this.info.maxSize = mOpts.maxSize * 1048576;
- }
- this.set = Object.assign({
- url : 'https://%s.online-convert.com%s?external_url=',
- conv : {
- Archive: {'7Z':{}, 'BZ2':{ext:'bz'}, 'GZ':{}, 'ZIP':{}},
- Audio: {'MP3':{}, 'OGG':{ext:'oga'}, 'WAV':{}, 'WMA':{}, 'AAC':{}, 'AIFF':{ext:'aif'}, 'FLAC':{}, 'M4A':{}, 'MMF':{}, 'OPUS':{ext:'oga'}},
- Document: {'DOC':{}, 'DOCX':{}, 'HTML':{}, 'ODT':{}, 'PDF':{}, 'PPT':{}, 'PPTX':{}, 'RTF':{}, 'SWF':{}, 'TXT':{}},
- eBook: {'AZW3':{ext:'azw'}, 'ePub':{}, 'FB2':{ext:'xml'}, 'LIT':{}, 'LRF':{}, 'MOBI':{}, 'PDB':{}, 'PDF':{},'PDF-eBook':{ext:'pdf'}, 'TCR':{}},
- Hash: {'Adler32':{}, 'Apache-htpasswd':{}, 'Blowfish':{}, 'CRC32':{}, 'CRC32B':{}, 'Gost':{}, 'Haval128':{},'MD4':{}, 'MD5':{}, 'RIPEMD128':{}, 'RIPEMD160':{}, 'SHA1':{}, 'SHA256':{}, 'SHA384':{}, 'SHA512':{}, 'Snefru':{}, 'Std-DES':{}, 'Tiger128':{}, 'Tiger128-calculator':{}, 'Tiger128-converter':{}, 'Tiger160':{}, 'Tiger192':{}, 'Whirlpool':{}},
- Image: {'BMP':{}, 'EPS':{ext:'ai'}, 'GIF':{}, 'EXR':{}, 'ICO':{}, 'JPG':{}, 'PNG':{}, 'SVG':{}, 'TGA':{}, 'TIFF':{ext:'tif'}, 'WBMP':{}, 'WebP':{}},
- Video: {'3G2':{}, '3GP':{}, 'AVI':{}, 'FLV':{}, 'HLS':{ext:'m3u8'}, 'MKV':{}, 'MOV':{}, 'MP4':{}, 'MPEG-1':{ext:'mpeg'}, 'MPEG-2':{ext:'mpeg'}, 'OGG':{ext:'ogv'}, 'OGV':{}, 'WebM':{}, 'WMV':{}, 'Android':{link:'/convert-video-for-%s',ext:'mp4'}, 'Blackberry':{link:'/convert-video-for-%s',ext:'mp4'}, 'DPG':{link:'/convert-video-for-%s',ext:'avi'}, 'iPad':{link:'/convert-video-for-%s',ext:'mp4'}, 'iPhone':{link:'/convert-video-for-%s',ext:'mp4'}, 'iPod':{link:'/convert-video-for-%s',ext:'mp4'}, 'Nintendo-3DS':{link:'/convert-video-for-%s',ext:'avi'}, 'Nintendo-DS':{link:'/convert-video-for-%s',ext:'avi'}, 'PS3':{link:'/convert-video-for-%s',ext:'mp4'}, 'Wii':{link:'/convert-video-for-%s',ext:'avi'}, 'Xbox':{link:'/convert-video-for-%s',ext:'wmv'}}
- },
- catExts : {
- Hash: 'txt'
- },
- link : '<div class="elfinder-edit-onlineconvert-link"><a href="https://www.online-convert.com" target="_blank"><span class="elfinder-button-icon"></span>ONLINE-CONVERT.COM</a></div>',
- useTabs : ($.fn.tabs && !fm.UA.iOS)? true : false // Can't work on iOS, I don't know why.
- }, mOpts);
- },
- // Prepare on before show dialog
- prepare : function(base, dialogOpts, file) {
- var elfNode = base.editor.fm.getUI();
- $(base).height(elfNode.height());
- dialogOpts.width = Math.max(dialogOpts.width || 0, elfNode.width() * 0.8);
- },
- // Initialization of editing node (this: this editors HTML node)
- init : function(id, file, dum, fm) {
- var ta = this,
- confObj = ta.editor.confObj,
- set = confObj.set,
- uiToast = fm.getUI('toast'),
- idxs = {},
- allowZip = fm.uploadMimeCheck('application/zip', file.phash),
- selfUrl = $('base').length? document.location.href.replace(/#.*$/, '') : '',
- getExt = function(cat, con) {
- var c;
- if (set.catExts[cat]) {
- return set.catExts[cat];
- }
- if (set.conv[cat] && (c = set.conv[cat][con])) {
- return (c.ext || con).toLowerCase();
- }
- return con.toLowerCase();
- },
- setOptions = function(cat, done) {
- var type, dfdInit, dfd;
- if (typeof confObj.api === 'undefined') {
- dfdInit = fm.request({
- data: {
- cmd: 'editor',
- name: 'OnlineConvert',
- method: 'init'
- },
- preventDefault : true
- });
- } else {
- dfdInit = $.Deferred().resolve({api: confObj.api});
- }
- cat = cat.toLowerCase();
- dfdInit.done(function(data) {
- confObj.api = data.api;
- if (confObj.api) {
- if (cat) {
- type = '?category=' + cat;
- } else {
- type = '';
- cat = 'all';
- }
- if (!confObj.conversions) {
- confObj.conversions = {};
- }
- if (!confObj.conversions[cat]) {
- dfd = $.getJSON('https://api2.online-convert.com/conversions' + type);
- } else {
- dfd = $.Deferred().resolve(confObj.conversions[cat]);
- }
- dfd.done(function(d) {
- confObj.conversions[cat] = d;
- $.each(d, function(i, o) {
- btns[set.useTabs? 'children' : 'find']('.onlineconvert-category-' + o.category).children('.onlineconvert-' + o.target).trigger('makeoption', o);
- });
- done && done();
- });
- }
- });
- },
- btns = (function() {
- var btns = $('<div></div>').on('click', 'button', function() {
- var b = $(this),
- opts = b.data('opts') || null,
- cat = b.closest('.onlineconvert-category').data('cname'),
- con = b.data('conv');
- if (confObj.api === true) {
- api({
- category: cat,
- convert: con,
- options: opts
- });
- }
- }).on('change', function(e) {
- var t = $(e.target),
- p = t.parent(),
- b = t.closest('.elfinder-edit-onlineconvert-button').children('button:first'),
- o = b.data('opts') || {},
- v = p.data('type') === 'boolean'? t.is(':checked') : t.val();
- e.stopPropagation();
- if (v) {
- if (p.data('type') === 'integer') {
- v = parseInt(v);
- }
- if (p.data('pattern')) {
- var reg = new RegExp(p.data('pattern'));
- if (!reg.test(v)) {
- requestAnimationFrame(function() {
- fm.error('"' + fm.escape(v) + '" is not match to "/' + fm.escape(p.data('pattern')) + '/"');
- });
- v = null;
- }
- }
- }
- if (v) {
- o[t.parent().data('optkey')] = v;
- } else {
- delete o[p.data('optkey')];
- }
- b.data('opts', o);
- }),
- ul = $('<ul></ul>'),
- oform = function(n, o) {
- var f = $('<p></p>').data('optkey', n).data('type', o.type),
- checked = '',
- disabled = '',
- nozip = false,
- opts, btn, elm;
- if (o.description) {
- f.attr('title', fm.i18n(o.description));
- }
- if (o.pattern) {
- f.data('pattern', o.pattern);
- }
- f.append($('<span></span>').text(fm.i18n(n) + ' : '));
- if (o.type === 'boolean') {
- if (o['default'] || (nozip = (n === 'allow_multiple_outputs' && !allowZip))) {
- checked = ' checked';
- if (nozip) {
- disabled = ' disabled';
- }
- btn = this.children('button:first');
- opts = btn.data('opts') || {};
- opts[n] = true;
- btn.data('opts', opts);
- }
- f.append($('<input type="checkbox" value="true"'+checked+disabled+'/>'));
- } else if (o['enum']){
- elm = $('<select></select>').append($('<option value=""></option>').text('Select...'));
- $.each(o['enum'], function(i, v) {
- elm.append($('<option value="'+v+'"></option>').text(v));
- });
- f.append(elm);
- } else {
- f.append($('<input type="text" value=""/>'));
- }
- return f;
- },
- makeOption = function(o) {
- var elm = this,
- b = $('<span class="elfinder-button-icon elfinder-button-icon-preference"></span>').on('click', function() {
- f.toggle();
- }),
- f = $('<div class="elfinder-edit-onlinconvert-options"></div>').hide();
- if (o.options) {
- $.each(o.options, function(k, v) {
- k !== 'download_password' && f.append(oform.call(elm, k, v));
- });
- }
- elm.append(b, f);
- },
- ts = (+new Date()),
- i = 0;
-
- if (!confObj.ext2mime) {
- confObj.ext2mime = Object.assign(fm.arrayFlip(fm.mimeTypes), ext2mime);
- }
- $.each(set.conv, function(t, c) {
- var cname = t.toLowerCase(),
- id = 'elfinder-edit-onlineconvert-' + cname + ts,
- type = $('<div id="' + id + '" class="onlineconvert-category onlineconvert-category-'+cname+'"></div>').data('cname', t),
- cext;
- $.each(c, function(n, o) {
- var nl = n.toLowerCase(),
- ext = getExt(t, n);
- if (!confObj.ext2mime[ext]) {
- if (cname === 'audio' || cname === 'image' || cname === 'video') {
- confObj.ext2mime[ext] = cname + '/x-' + nl;
- } else {
- confObj.ext2mime[ext] = 'application/octet-stream';
- }
- }
- if (fm.uploadMimeCheck(confObj.ext2mime[ext], file.phash)) {
- type.append($('<div class="elfinder-edit-onlineconvert-button onlineconvert-'+nl+'"></div>').on('makeoption', function(e, data) {
- var elm = $(this);
- if (!elm.children('.elfinder-button-icon-preference').length) {
- makeOption.call(elm, data);
- }
- }).append($('<button></button>').text(n).data('conv', n)));
- }
- });
- if (type.children().length) {
- ul.append($('<li></li>').append($('<a></a>').attr('href', selfUrl + '#' + id).text(t)));
- btns.append(type);
- idxs[cname] = i++;
- }
- });
- if (set.useTabs) {
- btns.prepend(ul).tabs({
- beforeActivate: function(e, ui) {
- setOptions(ui.newPanel.data('cname'));
- }
- });
- } else {
- $.each(set.conv, function(t) {
- var tl = t.toLowerCase();
- btns.append($('<fieldset class="onlineconvert-fieldset-' + tl + '"></fieldset>').append($('<legend></legend>').text(t)).append(btns.children('.onlineconvert-category-' + tl)));
- });
- }
- return btns;
- })(),
- select = $(this)
- .append(
- btns,
- (set.showLink? $(set.link) : null)
- ),
- spnr = $('<div class="elfinder-edit-spinner elfinder-edit-onlineconvert"></div>')
- .hide()
- .html('<span class="elfinder-spinner-text">' + fm.i18n('nowLoading') + '</span><span class="elfinder-spinner"></span>')
- .appendTo(select.parent()),
- prog = $('<div class="elfinder-quicklook-info-progress"></div>').appendTo(spnr),
- _url = null,
- url = function() {
- var onetime;
- if (_url) {
- return $.Deferred().resolve(_url);
- } else {
- spnr.show();
- return fm.forExternalUrl(file.hash, { progressBar: prog }).done(function(url) {
- _url = url;
- }).fail(function(error) {
- error && fm.error(error);
- ta.elfinderdialog('destroy');
- }).always(function() {
- spnr.hide();
- });
- }
- },
- api = function(opts) {
- $(ta).data('dfrd', url().done(function(url) {
- select.fadeOut();
- setStatus({info: 'Start conversion request.'});
- fm.request({
- data: {
- cmd: 'editor',
- name: 'OnlineConvert',
- method: 'api',
- 'args[category]' : opts.category.toLowerCase(),
- 'args[convert]' : opts.convert.toLowerCase(),
- 'args[options]' : JSON.stringify(opts.options),
- 'args[source]' : fm.convAbsUrl(url),
- 'args[filename]' : fm.splitFileExtention(file.name)[0] + '.' + getExt(opts.category, opts.convert),
- 'args[mime]' : file.mime
- },
- preventDefault : true
- }).done(function(data) {
- checkRes(data.apires, opts.category, opts.convert);
- }).fail(function(error) {
- error && fm.error(error);
- ta.elfinderdialog('destroy');
- });
- }));
- },
- checkRes = function(res, cat, con) {
- var status, err = [];
- if (res && res.id) {
- status = res.status;
- if (status.code === 'failed') {
- spnr.hide();
- if (res.errors && res.errors.length) {
- $.each(res.errors, function(i, o) {
- o.message && err.push(o.message);
- });
- }
- fm.error(err.length? err : status.info);
- select.fadeIn();
- } else if (status.code === 'completed') {
- upload(res);
- } else {
- setStatus(status);
- setTimeout(function() {
- polling(res.id);
- }, 1000);
- }
- } else {
- uiToast.appendTo(ta.closest('.ui-dialog'));
- if (res.message) {
- fm.toast({
- msg: fm.i18n(res.message),
- mode: 'error',
- timeOut: 5000,
- onHidden: function() {
- uiToast.children().length === 1 && uiToast.appendTo(fm.getUI());
- }
- });
- }
- fm.toast({
- msg: fm.i18n('editorConvNoApi'),
- mode: 'error',
- timeOut: 3000,
- onHidden: function() {
- uiToast.children().length === 1 && uiToast.appendTo(fm.getUI());
- }
- });
- spnr.hide();
- select.show();
- }
- },
- setStatus = function(status) {
- spnr.show().children('.elfinder-spinner-text').text(status.info);
- },
- polling = function(jobid) {
- fm.request({
- data: {
- cmd: 'editor',
- name: 'OnlineConvert',
- method: 'api',
- 'args[jobid]': jobid
- },
- preventDefault : true
- }).done(function(data) {
- checkRes(data.apires);
- }).fail(function(error) {
- error && fm.error(error);
- ta.elfinderdialog('destroy');
- });
- },
- upload = function(res) {
- var output = res.output,
- id = res.id,
- url = '';
- spnr.hide();
- if (output && output.length) {
- ta.elfinderdialog('destroy');
- $.each(output, function(i, o) {
- if (o.uri) {
- url += o.uri + '\n';
- }
- });
- fm.upload({
- target: file.phash,
- files: [url],
- type: 'text',
- extraData: {
- contentSaveId: 'OnlineConvert-' + res.id
- }
- });
- }
- },
- mode = 'document',
- cl, m;
- select.parent().css({overflow: 'auto'}).addClass('overflow-scrolling-touch');
- if (m = file.mime.match(/^(audio|image|video)/)) {
- mode = m[1];
- }
- if (set.useTabs) {
- if (idxs[mode]) {
- btns.tabs('option', 'active', idxs[mode]);
- }
- } else {
- cl = Object.keys(set.conv).length;
- $.each(set.conv, function(t) {
- if (t.toLowerCase() === mode) {
- setOptions(t, function() {
- $.each(set.conv, function(t0) {
- t0.toLowerCase() !== mode && setOptions(t0);
- });
- });
- return false;
- }
- cl--;
- });
- if (!cl) {
- $.each(set.conv, function(t) {
- setOptions(t);
- });
- }
- select.parent().scrollTop(btns.children('.onlineconvert-fieldset-' + mode).offset().top);
- }
- },
- load : function() {},
- getContent : function() {},
- save : function() {},
- // On dialog closed
- close : function(ta) {
- var fm = this.fm,
- dfrd = $(ta).data('dfrd');
- if (dfrd && dfrd.state() === 'pending') {
- dfrd.reject();
- }
- }
- }
- ];
- }, window.elFinder));
|