UNPKG

joywok-material-components

Version:

<h1 align="center"> Joywok Material Components </h1>

769 lines (710 loc) 34.2 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _fuploader = require('./fuploader'); var _fuploader2 = _interopRequireDefault(_fuploader); var _request = require('../utils/request'); var _request2 = _interopRequireDefault(_request); var _uploadaudio = require('./uploadaudio'); var _uploadaudio2 = _interopRequireDefault(_uploadaudio); var _uploadvideo = require('./uploadvideo'); var _uploadvideo2 = _interopRequireDefault(_uploadvideo); var _extplugin = require('./extplugin'); var _extplugin2 = _interopRequireDefault(_extplugin); var _ContentShow = require('./ContentShow'); var _ContentShow2 = _interopRequireDefault(_ContentShow); var _events = require('events'); var _Dialog = require('../utils/Dialog'); var _Dialog2 = _interopRequireDefault(_Dialog); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /** * * 请调用同目录中的 explugin.js * */ require('./style/index.css'); window.EditorEvts = new _events.EventEmitter(); var fetchingJs = false; var jwFormatFSize = function jwFormatFSize(fileSize) { if (fileSize < 1024) { return fileSize + 'B'; } else if (fileSize < 1024 * 1024) { var temp = fileSize / 1024; temp = temp.toFixed(2); return temp + 'KB'; } else if (fileSize < 1024 * 1024 * 1024) { var temp = fileSize / (1024 * 1024); temp = temp.toFixed(2); return temp + 'MB'; } else { var temp = fileSize / (1024 * 1024 * 1024); temp = temp.toFixed(2); return temp + 'GB'; } }; var formatAudioTime = function formatAudioTime(time) { var ret = time % 60; var minute = time % 3600; var hours = time % 86400; if (time > 3600) minute = time % 3600; if (time > 86400) hours = time % 86400; ret = Math.floor(minute / 60) + ':' + ret; if (time > 3600) ret = Math.floor(hours / 3600) + ':' + ret; ret = (ret + '').replace(/\b(\w)\b/g, '0$1'); if (time > 86400) ret = Math.floor(time / 86400) + 'D ' + ret; return ret; }; var JoywokEditor = function (_React$Component) { _inherits(JoywokEditor, _React$Component); _createClass(JoywokEditor, [{ key: 'saveDom', value: function saveDom() { this.checkChange(); var v = this.editor.getData(); typeof this.props.onChange === 'function' && this.props.onChange({ editor: this.editor }, v); } }, { key: 'checkChange', value: function checkChange() { this.editor.window.$.$ && this.editor.window.$.$('.jwh5audio').each(function () { $(this).removeClass('jwaudio-playing'); $(this).find('audio').get(0).pause(); }); } }, { key: 'componentWillReceiveProps', value: function componentWillReceiveProps(d) { var _this2 = this; d.defaultValue = d.defaultValue || ''; var editor = this.editor; // if(editor!==undefined){ this.setState({ value: d.defaultValue }); // } if (this.state.value !== d.defaultValue) { editor && editor.setData(d.defaultValue); } if (this.props.curLang !== d.curLang) { editor && editor.setData(d.defaultValue); } if (d.toolbarPosition === undefined) d.toolbarPosition = false; if (d.toolbarPosition !== this.state.toolbarPosition) { this.setState({ toolbarPosition: d.toolbarPosition }, function () { if (_this2.state.toolbarPosition !== false) { _this2.initToolbar(); } }); } } }, { key: 'getParFile', value: function getParFile(clsname, furl, type) { var _this3 = this; var url = furl; if (furl.indexOf('http') === 0) { (0, _request2.default)('/api/file/thirdimagelocal?appid=&app_type=jw_app_subscribe&url=' + encodeURIComponent(furl), { method: 'POST' }).then(function (resp) { if (resp.data && resp.data.JMVerinfo && resp.data.JMVerinfo.append) { if (resp.data.JMVerinfo.append.original === undefined) { url = resp.data.JMVerinfo.append.thumbnails.open_url; } else { url = resp.data.JMVerinfo.append.original.open_url; } } if (type === 1) { _this3.editor.window.$.$(clsname).attr('src', url).removeAttr('data-cke-saved-src').removeAttr('data-cke-widget-data'); } else if (type === 2) { _this3.editor.window.$.$(clsname).css('background-image', 'url(' + url + ')'); } _this3.saveDom(); }); } } }, { key: 'componentDidMount', value: function componentDidMount() { var _this4 = this; var that = this; if (this.props.onRef) this.props.onRef(this); CKEDITOR.replace(this.state.className, this.state.editorConfig); CKEDITOR.instances[this.state.className].on('contentDom', function (e) { console.log('contentDom', e); that.checkJS(); }); CKEDITOR.instances[this.state.className].on('configLoaded', function (e) { console.log('configLoaded'); }); CKEDITOR.instances[this.state.className].on('loaded', function (e) { that.editor = e.editor; // console.log('loaded'); }); CKEDITOR.instances[this.state.className].on('change', function (e2) { // console.log('change'); that.onChange(e2); }); CKEDITOR.instances[this.state.className].on('addimg', function (ed) { $('#up' + _this4.state.className).click(); }); CKEDITOR.instances[this.state.className].on('addaudio', function (ed) { _this4.insertAudio(CKEDITOR.instances[_this4.state.className]); }); CKEDITOR.instances[this.state.className].on('addvideo', function (ed) { _this4.insertVideo(ed.editor); }); CKEDITOR.instances[this.state.className].on('afterPaste', function (ee) { // that.checkJS(()=>{ var win = ee.editor.window.$; var vimgs = win.$('img'); vimgs.each(function () { var vsrc = $(this).attr('src'); if (vsrc.indexOf('/openfile/') != -1 || vsrc.indexOf('/api2/') != -1 || vsrc.indexOf('/public/') != -1 || vsrc.indexOf('/dist/') != -1 || vsrc.indexOf('/file/') != -1) { return; } else { var clsname = 'f_' + that.guid(); $(this).attr('id', clsname); that.getParFile('#' + clsname, vsrc, 1); } }); var vsection = win.$('section'); vsection.each(function () { var st = $(this).attr('style'); if (st != undefined) { var backg = $(this).css('background'); if (typeof backg == 'string') { if (backg.indexOf('url(') != -1) { backg = /url\((.*?)\)/ig.exec(backg); backg = backg[1]; backg = backg.replace(/\"/ig, ''); if (backg.indexOf('/openfile/') != -1 || backg.indexOf('/api2/') != -1 || backg.indexOf('/public/') != -1 || backg.indexOf('/dist/') != -1 || backg.indexOf('/file/') != -1) { return; } else { var clsname = 'f_' + that.guid(); $(this).attr('id', clsname); that.getParFile('#' + clsname, backg, 2); } } } } }); var tables = win.$('table'); tables.each(function () { var width = this.style.width; if (!_.isEmpty(width)) { this.style.width = '100%'; } }); that.saveDom(); // }) }); CKEDITOR.instances[this.state.className].on('instanceReady', function (e) { console.log('ready'); _this4.editor = e.editor; if (_this4.state.value === '') { _this4.editor.setData('&#8203;'); } else { _this4.editor.setData(_this4.state.value); } if (_this4.state.toolbarPosition !== false) { _this4.initToolbar(); } window.EditorEvts.addListener('changeContent', function () { _this4.onChange(e); }); var timer = false; if (_this4.props.simple === true) { if (window.PubSub) { window.PubSub.unsubscribe('editorChangeValue'); window.PubSub.subscribe('editorChangeValue', function (v, d) { e.editor.setData(d); }); } } }); } }, { key: 'checkEditor', value: function checkEditor() { var _this5 = this; var focusM = new CKEDITOR.focusManager(this.editor); var acNode = focusM.currentActive; if (acNode) { if (acNode.$.nodeName === 'BODY') { var childs = acNode.getChildren(); if (childs.count() > 0) { var texti = '&#8203;'; if (childs.getItem(childs.count() - 1).$.nodeType !== 3) { $(childs.getItem(childs.count() - 1).$).after(texti); setTimeout(function () { var range = new CKEDITOR.dom.range(_this5.editor.document); range.moveToElementEditEnd(childs.getItem(childs.count() - 1)); range.collapse(true); }, 100); } } } } } }, { key: 'checkJS', value: function checkJS(cb) { var that = this; if (this.editor) { var v = this.editor.getData(); if (v === 'undefined') { this.editor.setData(''); } } // if( fetchingJs===true ){ // // if(typeof cb==='function') cb(); // return; // } if (this.editor.document.$.getElementById('jwckpluginjs') !== null) { if (typeof cb === 'function') cb(); return; } // fetchingJs = true; var extjs = this.editor.document.$.createElement('script'); extjs.type = 'text/javascript'; extjs.id = 'jwckpluginjs'; extjs.src = '/dist/scripts/ck4c/jwplugins.js?v=' + (window.version || this.guid()); if (this.editor.document.$.getElementById('jwckpluginjs')) this.editor.document.$.getElementById('jwckpluginjs').remove(); this.editor.document.$.head.appendChild(extjs); var style = this.editor.document.$.createElement('link'); style.type = 'text/css'; style.rel = 'stylesheet'; style.id = 'jwckplugincss'; style.href = '/dist/scripts/ck4c/jwplugins.css?v=' + (window.version || this.guid()); style.addEventListener('load', function () { fetchingJs = false; if (typeof cb === 'function') cb(); }, false); if (this.editor.document.$.getElementById('jwckplugincss')) this.editor.document.$.getElementById('jwckplugincss').remove(); this.editor.document.$.head.appendChild(style); $(this.editor.window.$).unbind('keydown'); $(this.editor.window.$).keydown(function (e) { if (e.keyCode === 8) { that.checkEditor(); } }); $(this.editor.window.$).unbind('mouseover'); $(this.editor.window.$).mouseover(function () { that.checkEditor(); }); } // checkJS(cb){ // if(this.editor.document.$.getElementById('jwckpluginjs')===null){ // if(this.state.fetchTimer) clearTimeout(this.state.fetchTimer); // this.state.fetchTimer = setTimeout(()=>{ // var extjs = this.editor.document.$.createElement('script'); // extjs.type='text/javascript'; // extjs.id='jwckpluginjs'; // extjs.src='/public/scripts/ck4c/jwplugins.js?v='+window.version; // extjs.addEventListener('load', function(){ // if(typeof cb==='function') cb(); // }, false); // this.editor.document.$.head.appendChild( extjs ); // let style = this.editor.document.$.createElement('link'); // style.type='text/css'; // style.rel='stylesheet'; // style.href='/public/scripts/ck4c/jwplugins.css?v='+window.version; // this.editor.document.$.head.appendChild( style ); // }, 200) // }else{ // if(typeof cb==='function') cb(); // } // } }, { key: 'render', value: function render() { var value = this.state.value; // let value = this.props.defaultValue; return _react2.default.createElement( 'div', { className: 'joywok-editor ' + this.state.toolbarStyle }, _react2.default.createElement( 'textarea', { id: this.state.className }, value ), _react2.default.createElement(_fuploader2.default, { appType: this.props.appType, appId: this.props.appId, id: 'up' + this.state.className, className: 'insertImageInput', multiple: true, beforeUpload: this.beforeUploadImage, onChange: this.uploadImage, action: '/api/file/upload', accept: this.state.imageFormat }) ); } }, { key: 'insertItem', value: function insertItem(str) { var el = CKEDITOR.dom.element.createFromHtml(str); this.editor.insertElement(el); } }, { key: 'insertLoading', value: function insertLoading(file) { var el = CKEDITOR.dom.element.createFromHtml('<img src="/dist/images/loading.gif" id="fid_' + file.uid + '" />'); this.editor.insertElement(el); } }, { key: 'checkFile', value: function checkFile(file, callback) { return new Promise(function (res, rej) { new jwFSha1({ file: file, cb: function cb(tsha1) { var url = "/api/file/fileifexist?tsha1=" + tsha1 + "&jwfile=" + encodeURIComponent(encodeURIComponent(file.name)) + "&size=" + file.size + "&app_type=jw_n_subscribe"; (0, _request2.default)(url, { method: 'GET' }).then(function (d) { if (d.data && d.data.JMAttachment && d.data.JMAttachment.id) { callback(d.data.JMAttachment); rej({ error: 'has file' }); } else { if (d.data && d.data.errcode && d.data.errcode === 'no-network') { rej({ error: d.data.errmemo }); } else { res(1); } } }); } }); }); } }, { key: 'getImageUrl', value: function getImageUrl(file) { if (file.JMAttachment) file = file.JMAttachment; var url = ''; if ((file.ext_name + '').toLowerCase() === 'gif') { url = 'original'; } else { url = 'preview'; } url = '/openfile/getfile?id=' + file.id + '&type=jw_n_image&size=' + url; return url; } }, { key: 'fixTokenUrl', value: function fixTokenUrl(url) { url = url.replace(/\/api2\//ig, '/'); if (url.indexOf('/api') === 0) { if (url.indexOf('access_token') === -1) { url = url + '&access_token=' + window.token; } } return url; } }, { key: 'breakParent', value: function breakParent(id) { var element = new CKEDITOR.dom.element(this.editor.window.$.$('#' + id).get(0)); var p = this.editor.window.$.$('#' + id).parent().get(0); if (p.tagName && (p.tagName + '').toLowerCase() === 'span') { var parent_element = new CKEDITOR.dom.element(p); element.breakParent(parent_element); } } }, { key: 'insertAudio', value: function insertAudio() { var _this6 = this; var that = this; var a = (0, _Dialog2.default)({ app: window.dvaApp, data: { open: true, actions: [], onClose: function onClose() { a.close(); } }, component: function component() { return _react2.default.createElement(_uploadaudio2.default, { onOk: function onOk(file) { _this6.insertAudioToContent(file); a.close(); }, appType: that.props.appType, appId: that.props.appId, cancel: function cancel() { return a.close(); }, format: _this6.props.config.audioFormat }); } }); } }, { key: 'getVideoStr', value: function getVideoStr(v) { // d:{ coverUrl:'', videoUrl:''} // urlData: {cover: '', title: '', url: ''} // // <iframe frameborder="0" width="300" height="150" allow="autoplay; fullscreen" allowfullscreen="true" src={"//v.qq.com/txp/iframe/player.html?origin="+encodeURIComponent(location.origin)+"&vid="+this.getVid(self.state.urlData.url)+"&autoplay=false&show1080p=false&isDebugIframe=false"}> var str = ''; var removeBtn = '<section style="display:none;" class="em-video-remove-btn"><svg viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg"><g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g transform="translate(-2434.000000, -531.000000)"><g transform="translate(2434.000000, 531.000000)"><polygon id="Bounds" points="-3.66072173e-11 0 24 0 24 24 -3.66072173e-11 24"></polygon><path d="M8,21 L16,21 C17.1,21 18,20.1 18,19 L18,7 L6,7 L6,19 C6,20.1 6.9,21 8,21 Z M15.5,4 L14.5,3 L9.5,3 L8.5,4 L5,4 L5,6 L19,6 L19,4 L15.5,4 Z" id="Shape" fill="#777777"></path></g></g></g></svg></section>'; if (v.urlData) { var qq_reg = /https?:\/\/v.qq.com(.*\/)?(.{11})\.html/; var matches = qq_reg.exec(v.urlData.url); str = ''; if (matches === null) { str = '<section>' + i18n('label.pubsub-video-link-error') + '</section>'; } else { var vid = matches[2]; var src = '//v.qq.com/txp/iframe/player.html?origin=' + encodeURIComponent(location.origin) + '&vid=' + vid + '&autoplay=false&show1080p=false&isDebugIframe=false'; str = '<section><section class="tencent_video_container">' + removeBtn + '<iframe allow="autoplay; fullscreen" allowfullscreen="true" src="' + src + '"></iframe></section></section>'; } } else { var cover = (v.coverUrl + '').replace('/api2', ''); var bg = ''; if (cover === '' || cover === undefined) {} else { if (cover.indexOf('/file/viewpreview?id=') !== -1) { cover = cover.replace('/file/viewpreview?id=', '/openfile/getfile?size=preview&type=jw_n_image&id='); } bg = '<section class="ed_video_preview"><section class="ed_video_preview_img" style="background-image:url(' + cover + ')"></section></section><section class="ed_video_preview_btn"></section>'; } str = '<section><section class="ed_video_p_w" style="position: relative;" contenteditable="false">' + removeBtn + '<section class="ed_video_player"><video src="' + (v.videoUrl + '').replace('/api2', '') + '" controls="controls" controlslist="nodownload nofullscreen"></video></section>' + bg + '</section></section>'; } return str; } }, { key: 'initConfig', value: function initConfig() { CKEDITOR.dtd.$block.svg = 1; CKEDITOR.dtd.$block.g = 1; CKEDITOR.dtd.$block.polygon = 1; CKEDITOR.dtd.$block.path = 1; CKEDITOR.dtd.polygon = { '#': 1, style: 1 }; CKEDITOR.dtd.path = { '#': 1, style: 1 }; CKEDITOR.dtd.foreignObject = { '#': 1, style: 1, svg: 1 }; CKEDITOR.dtd.animateTransform = { '#': 1, style: 1 }; CKEDITOR.dtd.rect = { '#': 1, style: 1, animate: 1, path: 1 }; CKEDITOR.dtd.animate = { '#': 1, style: 1, animate: 1, rect: 1, g: 1, path: 1 }; CKEDITOR.dtd.g = { '#': 1, style: 1, polygon: 1, path: 1, g: 1, rect: 1, animate: 1, animateTransform: 1, foreignObject: 1 }; CKEDITOR.dtd.svg = { '#': 1, style: 1, polygon: 1, path: 1, g: 1, rect: 1, animate: 1, text: 1, svg: 1, animateTransform: 1, foreignObject: 1 }; CKEDITOR.dtd.section.svg = 1; CKEDITOR.dtd.div.svg = 1; CKEDITOR.dtd.p.svg = 1; CKEDITOR.dtd.td.svg = 1; var defConfig = { fillEmptyBlocks: false, linkDefaultProtocol: 'https://', extraPlugins: 'magicline,autogrow,insertimage,insertaudio,insertvideo', // extraPlugins: 'autogrow,insertimage', autoGrow_onStartup: true, autoGrow_maxHeight: 350, autoGrow_minHeight: 350, // height: 300, enterMode: 2, // CKEDITOR.ENTER_BR, shiftEnterMode: 3, // CKEDITOR.ENTER_DIV, // allowedContent: true, // allowedContent: { // $1: { // elements: CKEDITOR.dtd, // attributes: true, // styles: true, // classes: true // } // }, // disallowedContent: 'script; *[on*]; p div{line*, font*, max*, color*, white*, word*, letter*, -webkit*, background*, overflow*, position}; span{display, width}', allowedContent: { $1: { elements: CKEDITOR.dtd, attributes: true, styles: true, classes: true } }, disallowedContent: 'script; *[on*]; section{pointer*}; p div{color*, white*, word*, letter*}', pasteFilter: null, fontSize_defaultLabel: '16', fontSize_sizes: '12/12px;13/13px;14/14px;16/16px;18/18px;20/20px;22/22px;24/24px;28/28px;32/32px;48/48px;72/72px;96/96px;', line_height: "1;1.5;1.7;2;3;4;5;6;7;8;9;10", // removeButtons: 'placeholder,createplaceholder,emojipanel,emoji,brclear,Font,letterspacing,Format,Styles,Iframe,PageBreak,Replace,Flash,Language,PasteText,Save,About,Placeholder,Source,Preview,Templates,Cut,Copy,Paste,PasteFromWord,Blockquote,CreateDiv,BidiLtr,BidiRtl,Unlink,Anchor,Image,HorizontalRule,Maximize,ShowBlocks', // removePlugins:'elementspath,resize', // removeFormatAttributes: 'class,style,lang,width,height,align,hspace,valign', // removeFormatTags: 'b,big,code,del,dfn,em,font,i,ins,kbd,q,samp,small,span,strike,script,strong,sub,sup,tt,u,var', removeDialogTabs: 'link:advanced', language: window.cur_lang || 'zh-cn', removeButtons: 'Cut,Copy,Paste,Anchor,Font,Unlink', toolbarGroups: [{ name: 'document', groups: ['mode', 'document', 'doctools'] }, { name: 'clipboard', groups: ['clipboard', 'undo'] }, { name: 'editing', groups: ['find', 'selection', 'spellchecker', 'editing'] }, { name: 'forms', groups: ['forms'] }, { name: 'basicstyles', groups: ['basicstyles', 'cleanup'] }, { name: 'colors', groups: ['colors'] }, { name: 'customobj', groups: ['insertimage', 'insertvideo', 'insertaudio'] }, '/', { name: 'paragraph', groups: ['list', 'indent', 'blocks', 'align', 'bidi', 'paragraph'] }, { name: 'links', groups: ['links'] }, { name: 'insert', groups: ['insert'] }, { name: 'styles', groups: ['styles'] }, { name: 'tools', groups: ['tools'] }, { name: 'others', groups: ['others'] }, { name: 'about', groups: ['about'] }], contentsCss: [] //'/public/scripts/ck4c/jwplugins.css', }; var config = this.props.config === undefined ? {} : this.props.config; config = _.extend(defConfig, config); this.state = { curLang: this.props.curLang, value: this.props.defaultValue || '', toolbarPosition: this.props.toolbarPosition || false, editorName: this.props.editorName || 'JWCK' + this.guid(), className: this.props.className || 'jwck_' + this.guid(), toolbarStyle: this.props.toolbarStyle, editorConfig: config, showAudioDialog: false, showVideoDialog: false, imageFormat: this.props.config.imageFormat || ['.png', '.jpg', '.jpeg', '.bmp', '.gif'], videoFormat: this.props.config.videoFormat || ['.mp4', '.mpeg', '.mpg', '.avi', '.asf', '.wmv', '.mov', '.3gp', '.flv', '.h264', '.mkv', '.rm', '.rmvb'], showAudioCoverDilog: false }; } }, { key: 'initToolbar', value: function initToolbar() { var _this7 = this; if ($('#' + this.state.editorName + ' .cke_top').length === 0) { setTimeout(function () { _this7.initToolbar(); }, 100); } else { $('#' + this.state.editorName + ' .jwedtoolbar div').replaceWith($('#' + this.state.editorName + ' .cke_top')); } } }]); function JoywokEditor(props) { _classCallCheck(this, JoywokEditor); var _this = _possibleConstructorReturn(this, (JoywokEditor.__proto__ || Object.getPrototypeOf(JoywokEditor)).call(this, props)); _this.onChange = function (e) { _this.checkChange(); var v = e.editor.getData(); typeof _this.props.onChange === 'function' && _this.props.onChange(e, v); }; _this.beforeUploadImage = function (file) { _this.insertLoading(file); return _this.checkFile(file, function (response) { var item = _this.editor.document.$.getElementById('fid_' + file.uid); var itemP = item.parentNode; itemP.replaceChild($('<img src="' + _this.getImageUrl(response) + '" />').get(0), item); var div = $('<div><br /></div>').get(0); itemP.appendChild(div); _this.saveDom(); }); }; _this.uploadImage = function (e) { if (e.file.status === 'done') { var item = _this.editor.document.$.getElementById('fid_' + e.file.uid); var itemP = item.parentNode; itemP.replaceChild($('<img src="' + _this.getImageUrl(e.file.response) + '" />').get(0), item); var div = $('<div><br /></div>').get(0); itemP.appendChild(div); _this.saveDom(); } }; _this.insertAudioToContentCommon = function (file) { var item = _this.editor.document.$.getElementById('fid_' + file.uid); _this.breakParent('fid_' + file.uid); var itemP = item.parentNode; var url = _this.fixTokenUrl(file.response.mp3); var str = '<div><section class="jwh5audio-w"><section class="jwh5audio" contenteditable="false" style="width: 0;height: 0;background-color: #f7f7f7;padding-right: 100%;padding-bottom: 15.2%;position: relative;">\ <section class="jwh5audio1" style="width: 22.2%; height: 100%; background-color: #31C27C; position: absolute; left: 0; top: 0; background-position: center; background-size: cover; background-image: url(' + file.response.cover + ');">\ <section style="position: absolute; left: 35.5%; top: 30%; width: 27%; height: 39%; background-color: rgba(0, 0, 0, .3); border: 1px solid #fff; border-radius: 100%;">\ <section style="position: absolute; left: 39%; top: 35%; width: 0; height: 0; border-width: .4rem 0 .4rem .6rem; border-style: solid; border-color: transparent transparent transparent #fff;"></section>\ <audio src="' + url + '" style="position: absolute; left:0; right:0; top: 0; bottom:0;"></audio>\ </section>\ </section>\ <section class="jwh5audio2" style="position: absolute; color: #333; left: 26%; top: 19%; right: 13%; font-size: 1.3rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;">' + file.name + '</section>\ <section class="jwh5audio3" style="position: absolute; left: 26%; color: #999; top: 55%; right: 13%; font-size: 1rem; white-space: nowrap;">' + formatAudioTime(file.response.audio_time) + ' | ' + jwFormatFSize(file.size) + '</section>\ <section class="jwh5audio4" style="position: absolute; top: 40%; right: 3%; width: 2.8%; height: 18%; background-size:16px 14px; background-position: 0 center; background-repeat: repeat-x; background-image: url();"></section>\ </section>\ <section class="jwh5audio5" style="display:none;"><svg class="jwpubsub_event_del" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg"><g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g transform="translate(-2434.000000, -531.000000)"><g transform="translate(2434.000000, 531.000000)"><polygon id="Bounds" points="-3.66072173e-11 0 24 0 24 24 -3.66072173e-11 24"></polygon><path d="M8,21 L16,21 C17.1,21 18,20.1 18,19 L18,7 L6,7 L6,19 C6,20.1 6.9,21 8,21 Z M15.5,4 L14.5,3 L9.5,3 L8.5,4 L5,4 L5,6 L19,6 L19,4 L15.5,4 Z" id="Shape" fill="#777777"></path></g></g></g></svg></section>\ </section></div>'; itemP.replaceChild($(str).get(0), item); _this.setState({ showAudioDialog: false }); }; _this.insertAudioToContent = function (file) { _this.insertLoading(file); _this.insertAudioToContentCommon(file); _this.saveDom(); }; _this.insertVideoToContent = function (d) { var rid = _this.guid(); _this.insertLoading({ uid: rid }); var str = _this.getVideoStr(d); var item = _this.editor.document.$.getElementById('fid_' + rid); var itemP = item.parentNode; itemP.replaceChild($(str).get(0), item); _this.setState({ showVideoDialog: false }); }; _this.insertVideo = function (d) { // this.setState({showVideoDialog: true}); var that = _this; var a = (0, _Dialog2.default)({ app: window.dvaApp, data: { open: true, actions: [], onClose: function onClose() { a.close(); } }, component: function component() { return _react2.default.createElement(_uploadvideo2.default, { submit: function submit(d) { var rid = _this.guid(); _this.insertLoading({ uid: rid }); var str = _this.getVideoStr(d); var item = _this.editor.document.$.getElementById('fid_' + rid); var itemP = item.parentNode; itemP.replaceChild($(str).get(0), item); _this.saveDom(); a.close(); }, appType: that.props.appType, appId: that.props.appId, cancel: function cancel() { a.close(); } }); } }); }; _this.initConfig(); return _this; } _createClass(JoywokEditor, [{ key: 'guid', value: function guid() { function S4() { return ((1 + Math.random()) * 0x10000 | 0).toString(16).substring(1); } return S4() + S4() + S4() + S4() + S4() + S4() + S4() + S4(); } }]); return JoywokEditor; }(_react2.default.Component); JoywokEditor.EditorExtPlugin = _extplugin2.default; JoywokEditor.EditorContentShow = _ContentShow2.default; exports.default = JoywokEditor;