21 changed files with 550 additions and 1792 deletions
@ -0,0 +1,7 @@ |
|||||
|
// Exports the "anchor" plugin for usage with module loaders
|
||||
|
// Usage:
|
||||
|
// CommonJS:
|
||||
|
// require('tinymce/plugins/anchor')
|
||||
|
// ES2015:
|
||||
|
// import 'tinymce/plugins/anchor'
|
||||
|
require('./plugin.js') |
@ -0,0 +1,254 @@ |
|||||
|
|
||||
|
import { |
||||
|
loadJS_ifrEditArea, |
||||
|
loadCSS_ifrEditArea, |
||||
|
isPlugin, |
||||
|
// updateElm,
|
||||
|
updateAttrib, |
||||
|
getIdByClassName, |
||||
|
__assign, |
||||
|
isElm |
||||
|
// dataFormToElmPartStr,
|
||||
|
// elmToDataForm,
|
||||
|
// hasElm
|
||||
|
} |
||||
|
from '../hm_utils/index' |
||||
|
(function() { |
||||
|
'use strict' |
||||
|
|
||||
|
const pluginOptions = { |
||||
|
jsArr: [], |
||||
|
cssArr: [], |
||||
|
name: 'hmupload', |
||||
|
className: 'hmupload', // 判断依据,建议和name值一致
|
||||
|
cmdName: 'cmdhmupload', |
||||
|
editName: 'hmupload_edit', |
||||
|
dataForm: { |
||||
|
'data-hm_id': '', |
||||
|
'data-hm_type': 'upload', |
||||
|
'img': '', |
||||
|
'value': '', |
||||
|
'style.marginTop': '' |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
const global = tinymce.util.Tools.resolve('tinymce.PluginManager') |
||||
|
|
||||
|
// 初始设置
|
||||
|
const setup = function(editor) { |
||||
|
// 编辑器初始化后执行
|
||||
|
editor.on('init', function() { |
||||
|
loadJS_ifrEditArea(editor, pluginOptions.jsArr) |
||||
|
loadCSS_ifrEditArea(editor, pluginOptions.cssArr) |
||||
|
}) |
||||
|
// 右键菜单,选定目标
|
||||
|
editor.on('contextmenu', function(evt) { |
||||
|
const elm = evt.target |
||||
|
editor.selection.select(elm) |
||||
|
}, true) |
||||
|
} |
||||
|
|
||||
|
const open = function(editor) { |
||||
|
editor.windowManager.open({ |
||||
|
title: '新增按钮', |
||||
|
size: 'normal', // 'normal', 'medium' or 'large'
|
||||
|
body: { |
||||
|
type: 'panel', |
||||
|
items: [ |
||||
|
{ |
||||
|
type: 'input', |
||||
|
name: 'data-hm_id', |
||||
|
label: '名称', |
||||
|
placeholder: '按钮名称' |
||||
|
}, |
||||
|
{ |
||||
|
type: 'input', |
||||
|
name: 'id', |
||||
|
label: '唯一ID', |
||||
|
placeholder: '唯一ID' |
||||
|
}, |
||||
|
{ |
||||
|
type: 'input', |
||||
|
name: 'class', |
||||
|
label: '样式名', |
||||
|
placeholder: '样式名' |
||||
|
} |
||||
|
// {
|
||||
|
// type: 'input',
|
||||
|
// name: 'spacing',
|
||||
|
// label: '间距',
|
||||
|
// placeholder: '距离顶部的间距'
|
||||
|
// }
|
||||
|
] |
||||
|
}, |
||||
|
initialData: elmToDataForm(editor, pluginOptions.dataForm, pluginOptions.className), |
||||
|
buttons: [ |
||||
|
{ |
||||
|
type: 'cancel', |
||||
|
name: 'cancel', |
||||
|
text: '取消' |
||||
|
}, |
||||
|
{ |
||||
|
type: 'submit', |
||||
|
name: 'save', |
||||
|
text: '确定', |
||||
|
primary: true |
||||
|
} |
||||
|
], |
||||
|
onSubmit: function(api) { |
||||
|
const dataForm = api.getData() |
||||
|
// console.log(dataForm)
|
||||
|
dataForm['data-hm_type'] = pluginOptions.dataForm['data-hm_type'] |
||||
|
const hmType = dataForm['data-hm_type'] |
||||
|
const className = pluginOptions.className |
||||
|
const elm = editor.selection.getNode() |
||||
|
|
||||
|
let ele_upload, elm_img |
||||
|
if (elm.className.indexOf(className + '-img') >= 0) { |
||||
|
ele_upload = isElm(elm.previousElementSibling, 'data-hm_type', hmType) ? elm.previousElementSibling : undefined |
||||
|
elm_img = elm |
||||
|
} else if (elm.className.indexOf(className) >= 0 && isElm(elm, 'data-hm_type', hmType)) { |
||||
|
ele_upload = elm |
||||
|
elm_img = isElm(elm, 'data-hm_type', hmType) ? elm.nextElementSibling : undefined |
||||
|
} |
||||
|
|
||||
|
if (elm && isPlugin(elm, className)) { |
||||
|
// console.log('更新', elm)
|
||||
|
// 更新
|
||||
|
updateElm(editor, ele_upload, elm_img, dataForm, changeHandler) |
||||
|
api.close() |
||||
|
} else { |
||||
|
// 插入
|
||||
|
// console.log('插入', dataForm)
|
||||
|
insertElm(editor, dataForm) |
||||
|
api.close() |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
// 右击编辑弹框回显
|
||||
|
const elmToDataForm = function(editor, initDataForm, pluginClassName) { |
||||
|
const elm = editor.selection.getNode() |
||||
|
const dataForm = __assign({}, initDataForm) |
||||
|
// console.log(dataForm)
|
||||
|
const hmType = initDataForm['data-hm_type'] |
||||
|
if (isPlugin(elm, pluginClassName)) { |
||||
|
let ele_upload, elm_img |
||||
|
if (elm.className.indexOf(pluginClassName + '-img') >= 0) { |
||||
|
ele_upload = isElm(elm.previousElementSibling, 'data-hm_type', hmType) ? elm.previousElementSibling : undefined |
||||
|
elm_img = elm |
||||
|
} else if (elm.className.indexOf(pluginClassName) >= 0 && isElm(elm, 'data-hm_type', hmType)) { |
||||
|
ele_upload = elm |
||||
|
elm_img = isElm(elm, 'data-hm_type', hmType) ? elm.nextElementSibling : undefined |
||||
|
} |
||||
|
// console.log(elm_img)
|
||||
|
// console.log(ele_upload)
|
||||
|
dataForm['data-hm_id'] = ele_upload.getAttribute('data-hm_id') |
||||
|
dataForm['id'] = ele_upload.getAttribute('id') |
||||
|
// dataForm['class'] = ele_upload.getAttribute('class') ? ele_upload.getAttribute('class').split(' ')[1] : ''
|
||||
|
// dataForm['spacing'] = elm.parentNode.style ? elm.parentNode.style.marginTop.replace('px', '') : ''
|
||||
|
} |
||||
|
return dataForm |
||||
|
} |
||||
|
|
||||
|
const insertElm = function(editor, dataForm) { |
||||
|
// console.log(dataForm)
|
||||
|
const doc = editor.contentDocument || editor.contentWindow.document |
||||
|
const className = pluginOptions.className |
||||
|
const id = getIdByClassName(doc, className) |
||||
|
const name = dataForm['data-hm_id'] |
||||
|
const hmType = dataForm['data-hm_type'] |
||||
|
const ID = dataForm['id'] |
||||
|
// const customClass = dataForm['class']
|
||||
|
// const imgList = dataForm['imgList']
|
||||
|
// const spacing = dataForm['spacing']
|
||||
|
const win = editor.contentWindow |
||||
|
// const domStr_upload = `<input type="file" multiple="multiple" id="${ID}" class="${className}" data-hm_type="${hmType}" data-hm_id="${name}" value="${name}"></input>`
|
||||
|
const domStr_upload = `<div class="uploadBtn" id="${ID}" data-hm_type="${hmType}" data-hm_id="${name}"><img src="" alt=""><input type="file" multiple="multiple" id="${ID}" class="${className}" data-hm_type="${hmType}" data-hm_id="${name}" value="${name}"></input></div>` |
||||
|
const divs = `<div class="div-uploads" style="margin-top:5px;"><ul id="div-${name}"></ul></div>` |
||||
|
editor.insertContent(domStr_upload + divs) |
||||
|
// 渲染控件
|
||||
|
renderElm(doc, win, id, dataForm['data-hm_type']) |
||||
|
} |
||||
|
const updateElm = function(editor, ele_upload, ele_img, dataForm, changeHandler) { |
||||
|
console.log(123, dataForm['data-hm_id']) |
||||
|
const name = dataForm['data-hm_id'] |
||||
|
const ID = dataForm['id'] |
||||
|
// const spacing = dataForm['spacing']
|
||||
|
const className = pluginOptions.className |
||||
|
const customClass = dataForm['class'] |
||||
|
if (ele_upload) { |
||||
|
updateAttrib(ele_upload, 'data-hm_id', name) |
||||
|
updateAttrib(ele_upload, 'id', ID) |
||||
|
updateAttrib(ele_upload, 'value', name) |
||||
|
updateAttrib(ele_upload, 'class', `${className} ${customClass}`) |
||||
|
// ele_upload.parentNode.style.marginTop = spacing + 'px'
|
||||
|
} |
||||
|
} |
||||
|
|
||||
|
// 编辑控件状态后,触发处理逻辑
|
||||
|
const changeHandler = function(editor, elm, dataForm) { |
||||
|
const doc = editor.contentDocument || editor.contentWindow.document |
||||
|
const win = editor.contentWindow |
||||
|
const id = editor.dom.getAttrib(elm, 'id') |
||||
|
|
||||
|
renderElm(doc, win, id, dataForm['data-hm_type']) |
||||
|
} |
||||
|
|
||||
|
const renderElm = function(doc, win, id, type) { |
||||
|
} |
||||
|
|
||||
|
const register = function(editor) { |
||||
|
editor.addCommand(pluginOptions.cmdName, function() { |
||||
|
open(editor) |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
const register$1 = function(editor) { |
||||
|
// 工具栏
|
||||
|
editor.ui.registry.addButton(pluginOptions.name, { |
||||
|
icon: 'upload', |
||||
|
title: '上传', |
||||
|
tooltip: '上传', |
||||
|
onAction: function() { |
||||
|
open(editor) |
||||
|
}, |
||||
|
onSetup: function(uploadApi) { |
||||
|
} |
||||
|
}) |
||||
|
// 菜单栏
|
||||
|
editor.ui.registry.addMenuItem(pluginOptions.name, { |
||||
|
icon: 'upload', |
||||
|
text: '上传', |
||||
|
onAction: function() { |
||||
|
open(editor) |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
// 菜单栏(编辑)
|
||||
|
editor.ui.registry.addMenuItem(pluginOptions.editName, { |
||||
|
icon: 'upload', |
||||
|
text: '编辑', |
||||
|
onAction: function() { |
||||
|
open(editor) |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
editor.ui.registry.addContextMenu(pluginOptions.name, { |
||||
|
update: function(elm) { |
||||
|
return isPlugin(elm, pluginOptions.className) ? [pluginOptions.editName] : [] |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
function Plugin() { |
||||
|
global.add(pluginOptions.name, function(editor) { |
||||
|
setup(editor) |
||||
|
register(editor) |
||||
|
register$1(editor) |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
Plugin() |
||||
|
}()) |
File diff suppressed because it is too large
Loading…
Reference in new issue