Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 551d4b78

Von Moritz Bunkus vor fast 11 Jahren hinzugefügt

  • ID 551d4b787115605d6b12ef199ea52ac6a5a2ad0c
  • Vorgänger cb31afcf
  • Nachfolger ecfae06f

kivi.js: ckeditor über Klasse »texteditor« nutzen können

Unterschiede anzeigen:

SL/ClientJS.pm
removeData => 2,
# Form Events
focus => 1,
focus => 1, # kivi.set_focus(<TARGET>)
# Generic Event Handling ## pattern: $(<TARGET>).<FUNCTION>(<ARG1>, kivi.get_function_by_name(<ARG2>))
on => 3,
......
'jstree:deselect_node' => 2,
'jstree:deselect_all' => 1,
# ## ckeditor stuff ##
'focus_ckeditor' => 1, # kivi.focus_ckeditor_when_ready(<TARGET>)
# ## other stuff ##
redirect_to => 1, # window.location.href = <TARGET>
......
return $self;
}
sub ckeditor {
my ($self) = @_;
$self->{_prefix} = 'ckeditor:';
return $self;
}
sub flash {
my ($self, $type, @messages) = @_;
js/client_js.js
else if (action[0] == 'removeData') $(action[1]).removeData(action[2]);
// Form Events
else if (action[0] == 'focus') $(action[1]).focus();
else if (action[0] == 'focus') kivi.set_focus(action[1]);
// Generic Event Handling ##
else if (action[0] == 'on') $(action[1]).on(action[2], kivi.get_function_by_name(action[3]));
......
else if (action[0] == 'jstree:deselect_node') $.jstree._reference($(action[1])).deselect_node(action[2]);
else if (action[0] == 'jstree:deselect_all') $.jstree._reference($(action[1])).deselect_all();
// ## ckeditor stuff ##
else if (action[0] == 'focus_ckeditor') kivi.focus_ckeditor_when_ready(action[1]);
// ## other stuff ##
else if (action[0] == 'redirect_to') window.location.href = action[1];
else if (action[0] == 'flash') kivi.display_flash(action[1], action[2]);
js/kivi.js
ns._locale = locale;
};
ns.set_focus = function(element) {
var $e = $(element).eq(0);
if ($e.data('ckeditorInstance'))
ns.focus_ckeditor_when_ready($e);
else
$e.focus();
};
ns.focus_ckeditor_when_ready = function(element) {
$(element).ckeditor(function() { ns.focus_ckeditor(element); });
};
ns.focus_ckeditor = function(element) {
var editor = $(element).ckeditorGet();
var editable = editor.editable();
if (editable.is('textarea')) {
var textarea = editable.$;
if (CKEDITOR.env.ie)
textarea.createTextRange().execCommand('SelectAll');
else {
textarea.selectionStart = 0;
textarea.selectionEnd = textarea.value.length;
}
textarea.focus();
} else {
if (editable.is('body'))
editor.document.$.execCommand('SelectAll', false, null);
else {
var range = editor.createRange();
range.selectNodeContents(editable);
range.select();
}
editor.forceNextSelectionCheck();
editor.selectionChange();
editor.focus();
}
};
ns.init_tabwidget = function(element) {
var $element = $(element);
var tabsParams = {};
......
$element.tabs(tabsParams);
};
ns.init_text_editor = function(element) {
var layouts = {
all: [ [ 'Bold', 'Italic', 'Underline', 'Strike', '-', 'Subscript', 'Superscript' ], [ 'BulletedList', 'NumberedList' ], [ 'RemoveFormat' ] ],
default: [ [ 'Bold', 'Italic', 'Underline', 'Strike', '-', 'Subscript', 'Superscript' ], [ 'BulletedList', 'NumberedList' ], [ 'RemoveFormat' ] ]
};
var $e = $(element);
var buttons = layouts[ $e.data('texteditor-layout') || 'default' ] || layouts['default'];
var config = {
entities: false,
language: 'de',
removePlugins: 'resize',
toolbar: buttons
}
var style = $e.prop('style');
$(['width', 'height']).each(function(idx, prop) {
var matches = (style[prop] || '').match(/(\d+)px/);
if (matches && (matches.length > 1))
config[prop] = matches[1];
});
$e.ckeditor(config);
if ($e.hasClass('texteditor-autofocus'))
$e.ckeditor(function() { ns.focus_ckeditor($e); });
};
ns.reinit_widgets = function() {
ns.run_once_for('.datepicker', 'datepicker', function(elt) {
$(elt).datepicker();
......
});
ns.run_once_for('.tabwidget', 'tabwidget', kivi.init_tabwidget);
ns.run_once_for('.texteditor', 'texteditor', kivi.init_text_editor);
};
ns.submit_ajax_form = function(url, form_selector, additional_data) {

Auch abrufbar als: Unified diff