X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fkivi.js;h=210020a60480dd6d0ceb0e415337082f4dae82e1;hb=de1e3e16945e61aac5eacfb254356d968add876d;hp=c6b70747308dcec930b7e74fcf8267b033cd82ee;hpb=36d1d6a42c18b4c7743c24ff3ebf02e81c470f7b;p=kivitendo-erp.git diff --git a/js/kivi.js b/js/kivi.js index c6b707473..210020a60 100644 --- a/js/kivi.js +++ b/js/kivi.js @@ -157,41 +157,39 @@ namespace("kivi", function(ns) { }; ns.focus_ckeditor_when_ready = function(element) { - $(element).ckeditor(function() { ns.focus_ckeditor(element); }); + $(element).data('ckeditorInstance').on('instanceReady', 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); + $(element).data('ckeditorInstance').focus(); + }; - else { - var range = editor.createRange(); - range.selectNodeContents(editable); - range.select(); - } + ns.selectall_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; + } + } else { + if (editable.is('body')) + editor.document.$.execCommand('SelectAll', false, null); - editor.forceNextSelectionCheck(); - editor.selectionChange(); + else { + var range = editor.createRange(); + range.selectNodeContents(editable); + range.select(); + } - editor.focus(); - } - }; + editor.forceNextSelectionCheck(); + editor.selectionChange(); + } + } ns.init_tabwidget = function(element) { var $element = $(element); @@ -222,20 +220,20 @@ namespace("kivi", function(ns) { entities: false, language: 'de', removePlugins: 'resize', - toolbar: buttons - } + extraPlugins: 'inline_resize', + toolbar: buttons, + disableAutoInline: true, + title: false + }; - 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]; - }); + config.height = $e.height(); + config.width = $e.width(); - $e.ckeditor(config); + var editor = CKEDITOR.inline($e.get(0), config); + $e.data('ckeditorInstance', editor); if ($e.hasClass('texteditor-autofocus')) - $e.ckeditor(function() { ns.focus_ckeditor($e); }); + editor.on('instanceReady', function() { ns.focus_ckeditor($e); }); }; ns.reinit_widgets = function() { @@ -243,21 +241,14 @@ namespace("kivi", function(ns) { $(elt).datepicker(); }); - if (ns.PartPicker) - ns.run_once_for('input.part_autocomplete', 'part_picker', function(elt) { - kivi.PartPicker($(elt)); - }); + if (ns.Part) ns.Part.reinit_widgets(); + if (ns.CustomerVendor) ns.CustomerVendor.reinit_widgets(); if (ns.ProjectPicker) ns.run_once_for('input.project_autocomplete', 'project_picker', function(elt) { kivi.ProjectPicker($(elt)); }); - if (ns.CustomerVendorPicker) - ns.run_once_for('input.customer_vendor_autocomplete', 'customer_vendor_picker', function(elt) { - kivi.CustomerVendorPicker($(elt)); - }); - if (ns.ChartPicker) ns.run_once_for('input.chart_autocomplete', 'chart_picker', function(elt) { kivi.ChartPicker($(elt)); @@ -360,13 +351,13 @@ namespace("kivi", function(ns) { params.dialog || { }, { // Options that must not be changed: close: function(event, ui) { + dialog.dialog('close'); + if (custom_close) custom_close(); if (params.url || params.html) dialog.remove(); - else - dialog.dialog('close'); } }); @@ -446,7 +437,7 @@ namespace("kivi", function(ns) { ns.run = function(function_name, args) { var fn = ns.get_function_by_name(function_name); if (fn) - return fn.apply({}, args); + return fn.apply({}, args || []); console.error('kivi.run("' + function_name + '"): No function by that name found'); return undefined; @@ -538,6 +529,23 @@ namespace("kivi", function(ns) { return true; }; + + ns.switch_areainput_to_textarea = function(id) { + var $input = $('#' + id); + if (!$input.length) + return; + + var $area = $(''); + + $area.prop('rows', 3); + $area.prop('cols', $input.prop('size') || 40); + $area.prop('name', $input.prop('name')); + $area.prop('id', $input.prop('id')); + $area.val($input.val()); + + $input.parent().replaceWith($area); + $area.focus(); + }; }); kivi = namespace('kivi');