2017-06-24 00:58:56 +03:00
|
|
|
<script type="text/javascript">
|
2017-11-17 12:02:05 +03:00
|
|
|
var mixedMode = {ldelim}
|
|
|
|
name: "htmlmixed",
|
|
|
|
scriptTypes: [
|
|
|
|
{ldelim}matches: /(text|application)\/(x-)?(html|httpd|php)/i, mode: "php"{rdelim}
|
|
|
|
]
|
|
|
|
{rdelim};
|
|
|
|
|
2017-06-24 00:58:56 +03:00
|
|
|
editor{$conn_id} = CodeMirror.fromTextArea(document.getElementById('{$textarea_id}'), {ldelim}
|
|
|
|
theme: '{$smarty.const.CODEMIRROR_THEME}',
|
|
|
|
foldGutter: true,
|
|
|
|
gutters: ["CodeMirror-linenumbers", "CodeMirror-foldgutter"],
|
|
|
|
extraKeys: {ldelim}
|
|
|
|
'Ctrl-S': function (cm) {ldelim}
|
|
|
|
{$ctrls}
|
|
|
|
{rdelim},
|
|
|
|
'Cmd-S': function (cm) {ldelim}
|
|
|
|
{$ctrls}
|
|
|
|
{rdelim},
|
|
|
|
'Ctrl-O': function (cm) {ldelim}
|
|
|
|
{$ctrlo}
|
|
|
|
{rdelim},
|
|
|
|
'Cmd-O': function (cm) {ldelim}
|
|
|
|
{$ctrlo}
|
|
|
|
{rdelim},
|
|
|
|
'Cmd-F11': function (cm) {ldelim}
|
|
|
|
var codem = $(cm.getWrapperElement());
|
|
|
|
if (codem.hasClass('CodeMirror-fullscreen')) $('body').css('overflow','auto');
|
|
|
|
else $('body').css('overflow','hidden');
|
|
|
|
codem.toggleClass('CodeMirror-fullscreen');
|
|
|
|
{rdelim},
|
|
|
|
'F11': function (cm) {ldelim}
|
|
|
|
var codem = $(cm.getWrapperElement());
|
|
|
|
if (codem.hasClass('CodeMirror-fullscreen')) $('body').css('overflow','auto');
|
|
|
|
else $('body').css('overflow','hidden');
|
|
|
|
codem.toggleClass('CodeMirror-fullscreen');
|
|
|
|
{rdelim},
|
|
|
|
'Esc': function (cm) {ldelim}
|
|
|
|
$('body').css('overflow','auto');
|
|
|
|
$(cm.getWrapperElement()).removeClass('CodeMirror-fullscreen');
|
|
|
|
{rdelim}
|
|
|
|
{rdelim},
|
|
|
|
readOnly: {if $readonly} true {else} false {/if},
|
|
|
|
lineNumbers: true,
|
|
|
|
lineWrapping: true,
|
|
|
|
matchBrackets: true,
|
|
|
|
mode: '{$mode|default:'application/x-httpd-php'}',
|
|
|
|
indentUnit: 4,
|
|
|
|
indentWithTabs: true,
|
|
|
|
enterMode: 'keep',
|
|
|
|
tabMode: 'shift',
|
|
|
|
autoCloseTags: true,
|
2018-04-19 19:11:58 +03:00
|
|
|
styleActiveLine: true,
|
|
|
|
smartyVersion : 2
|
2017-06-24 00:58:56 +03:00
|
|
|
{rdelim});
|
|
|
|
|
|
|
|
editor{$conn_id}.setSize('{$width|default:'100%'}', '{$height|default:'400px'}');
|
|
|
|
|
|
|
|
editor{$conn_id}.on('keypress', function(editor{$conn_id}, keypress) {ldelim}
|
|
|
|
editor{$conn_id}.save();
|
|
|
|
{rdelim});
|
|
|
|
|
|
|
|
editor{$conn_id}.on('change', function(editor{$conn_id}, change) {ldelim}
|
|
|
|
editor{$conn_id}.save();
|
|
|
|
{rdelim});
|
|
|
|
|
|
|
|
function getSelectedRange{$conn_id}() {ldelim}
|
|
|
|
return {ldelim}
|
|
|
|
from: editor{$conn_id}.getCursor(true),
|
|
|
|
to: editor{$conn_id}.getCursor(false)
|
|
|
|
{rdelim};
|
|
|
|
{rdelim}
|
|
|
|
|
|
|
|
function textSelection{$conn_id}(startTag, endTag) {ldelim}
|
|
|
|
var range = getSelectedRange{$conn_id}();
|
|
|
|
editor{$conn_id}.replaceRange(startTag + editor{$conn_id}.getRange(range.from, range.to) + endTag, range.from, range.to)
|
|
|
|
editor{$conn_id}.setCursor(range.from.line, range.from.ch + startTag.length);
|
|
|
|
editor{$conn_id}.save();
|
2017-11-17 12:02:05 +03:00
|
|
|
editor{$conn_id}.focus();
|
|
|
|
|
|
|
|
return false;
|
2017-06-24 00:58:56 +03:00
|
|
|
{rdelim}
|
2017-11-17 12:02:05 +03:00
|
|
|
</script>
|