![JAR search and dependency download from the Maven repository](/logo.png)
template.js.tinymce.plugins.codesample.classes.Dialog.js Maven / Gradle / Ivy
/**
* Dialog.js
*
* Released under LGPL License.
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
*
* License: http://www.tinymce.com/license
* Contributing: http://www.tinymce.com/contributing
*/
/**
* Contains all dialog logic.
*
* @class tinymce.codesample.Dialog
* @private
*/
define("tinymce/codesampleplugin/Dialog", [
"tinymce/dom/DOMUtils",
"tinymce/codesampleplugin/Utils",
"tinymce/codesampleplugin/Prism"
], function(DOMUtils, Utils, Prism) {
var DOM = DOMUtils.DOM;
var languages = [
{text: 'HTML/XML', value: 'markup'},
{text: 'JavaScript', value: 'javascript'},
{text: 'CSS', value: 'css'},
{text: 'PHP', value: 'php'},
{text: 'Ruby', value: 'ruby'},
{text: 'Python', value: 'python'},
{text: 'Java', value: 'java'},
{text: 'C', value: 'c'},
{text: 'C#', value: 'csharp'},
{text: 'C++', value: 'cpp'}
];
function insertCodeSample(editor, language, code) {
editor.undoManager.transact(function() {
var node = getSelectedCodeSample(editor);
code = DOM.encode(code);
if (node) {
editor.dom.setAttrib(node, 'class', 'language-' + language);
node.innerHTML = code;
Prism.highlightElement(node);
editor.selection.select(node);
} else {
editor.insertContent('' + code + '
');
editor.selection.select(editor.$('#__new').removeAttr('id')[0]);
}
});
}
function getSelectedCodeSample(editor) {
var node = editor.selection.getNode();
if (Utils.isCodeSample(node)) {
return node;
}
return null;
}
function getCurrentCode(editor) {
var node = getSelectedCodeSample(editor);
if (node) {
return node.textContent;
}
return '';
}
function getCurrentLanguage(editor) {
var matches, node = getSelectedCodeSample(editor);
if (node) {
matches = node.className.match(/language-(\w+)/);
return matches ? matches[1] : '';
}
return '';
}
return {
open: function(editor) {
editor.windowManager.open({
title: "Insert/Edit code sample",
minWidth: Math.min(DOM.getViewPort().w, 800),
minHeight: Math.min(DOM.getViewPort().h, 650),
layout: 'fit',
body: [
{
type: 'listbox',
name: 'language',
label: 'Language',
maxWidth: 200,
value: getCurrentLanguage(editor),
values: languages
},
{
type: 'textbox',
name: 'code',
multiline: true,
spellcheck: false,
ariaLabel: 'Code view',
flex: 1,
style: 'direction: ltr; text-align: left',
classes: 'monospace',
value: getCurrentCode(editor),
autofocus: true
}
],
onSubmit: function(e) {
insertCodeSample(editor, e.data.language, e.data.code);
}
});
}
};
});
© 2015 - 2025 Weber Informatics LLC | Privacy Policy